From 53a33956ff30ce9ab4a3b120a1a85cfd6f8d75c7 Mon Sep 17 00:00:00 2001 From: Leo Batyuk Date: Tue, 18 May 2021 15:27:07 +0200 Subject: [PATCH] Add associations with composite primary keys * BelongsTo * HasMany * ManyToMany --- integration_test/support/migration.exs | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/integration_test/support/migration.exs b/integration_test/support/migration.exs index c5c83b4c..db890cb7 100644 --- a/integration_test/support/migration.exs +++ b/integration_test/support/migration.exs @@ -27,6 +27,8 @@ defmodule Ecto.Integration.Migration do add :intensity, :float add :author_id, :integer add :posted, :date + add :composite_a, :integer + add :composite_b, :integer timestamps(null: true) end @@ -108,6 +110,26 @@ defmodule Ecto.Integration.Migration do add :name, :string end + create table(:composite_pk_composite_pk, primary_key: false) do + add :b_1, :integer + add :a_1, references(:composite_pk, column: :a, with: [b_1: :b], type: :integer) + add :b_2, :integer + add :a_2, references(:composite_pk, column: :a, with: [b_2: :b], type: :integer) + end + + + alter table(:posts) do + modify :composite_a, references(:composite_pk, column: :a, with: [composite_b: :b], type: :integer) + end + + create table(:posts_composite_pk) do + add :post_id, references(:posts), primary_key: true + add :composite_a, references(:composite_pk, column: :a, with: [composite_b: :b], type: :integer), primary_key: true + add :composite_b, :integer, primary_key: true + end + + create unique_index(:posts_composite_pk, [:post_id, :composite_a, :composite_b]) + create table(:corrupted_pk, primary_key: false) do add :a, :string end