gpt4 book ai didi

elixir - Phoenix 尝试构建数据库时出现 unique_constraint 错误

转载 作者:行者123 更新时间:2023-12-05 01:16:31 25 4
gpt4 key购买 nike

我正在阅读 Phoenix 1.4 这本书,当我尝试通过终端将数据输入到数据库时遇到错误,我进入了“使用存储库数据”部分。

我的 IEx session :

iex(1)> alias Rumbl.Repo
Rumbl.Repo
iex(2)> alias Rumbl.Accounts.User
Rumbl.Accounts.User
iex(3)> Repo.insert(%User{
...(3)> name: "José", username: "josevalim"
...(3)> })
[debug] QUERY ERROR db=16.7ms queue=1.2ms
INSERT INTO "users" ("name","username","inserted_at","updated_at") VALUES ($1,$2,$3,$4) RETURNING "id" ["José", "josevalim", ~N[2018-11-24 11:47:30], ~N[2018-11-24 11:47:30]]

它抛出了以下错误:

** (Ecto.ConstraintError) constraint error when attempting to insert struct:

* users_username_index (unique_constraint)

If you would like to stop this constraint violation from raising an
exception and instead add it as an error to your changeset, please
call `unique_constraint/3` on your changeset with the constraint
`:name` as an option.

The changeset has not defined any constraint.

(ecto) lib/ecto/repo/schema.ex:641: anonymous fn/4 in Ecto.Repo.Schema.constraints_to_errors/3
(elixir) lib/enum.ex:1314: Enum."-map/2-lists^map/1-0-"/2
(ecto) lib/ecto/repo/schema.ex:626: Ecto.Repo.Schema.constraints_to_errors/3
(ecto) lib/ecto/repo/schema.ex:238: anonymous fn/15 in Ecto.Repo.Schema.do_insert/3

最佳答案

您似乎创建了一个 unique index在您的 users 表迁移中

约束在您的 username 键上,这意味着 users 表中的两条记录不能具有相同的用户名。在您的情况下,这意味着您已经在表中使用用户名 josevalim 创建了另一个用户。


要让 Ecto 返回 {:error, changeset} 元组而不是引发错误,您可以告诉模式有一个 unique constraint在你的 changeset/2 方法中:

def changeset(user, params) do
user
|> cast(params, [:name, :username])
|> validate_required([:name, :username])
|> unique_constraint(:username, name: :users_username_index)
end

并在插入任何内容之前使用此方法构建变更集:

%User{}
|> changeset(%{name: "José", username: "josevalim"})
|> Repo.insert

关于elixir - Phoenix 尝试构建数据库时出现 unique_constraint 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53457966/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com