Reputation: 2961
Ecto is throwing me the following error:
** (exit) an exception was raised:
** (Ecto.ConstraintError) constraint error when attempting to insert struct:
* unique: res_users_login_key
If you would like to convert this constraint into an error, please
call unique_constraint/3 in your changeset and define the proper
constraint name. The changeset defined the following constraints:
* unique: res_users_login_index
Do I understand correctly that the actual name of the constraint in postgresql determines if the unique_constraint/3 function is successful or not? Just for reference, in postgreSQL the constraint is defined as follows:
Indexes:
"res_users_pkey" PRIMARY KEY, btree (id)
"res_users_login_key" UNIQUE CONSTRAINT, btree (login)
so _key
and not _index
.
I call the constraint function as follows:
changeset |> unique_constraint(:login)
So, how do I make this work?
Upvotes: 2
Views: 692
Reputation: 222138
The constraint name used by Ecto when one is not given is #{table_name}_#{field}_index
. Your table is probably named res_users
, and the field is login
, which is why Ecto uses the constraint name res_users_login_index
, which is incorrect in your case. You'll need to explicitly specify the name res_users_login_key
in the call to unique_constraint
:
|> unique_constraint(:login, [name: :res_users_login_key])
Upvotes: 3