我有一个旧的迁移,用于更新角色数组字段中用户的角色。
这个迁移不再运行,因为今天我在模式中添加了一个名为is_bot的字段。
以下是我的迁移过程:

def up do
  query =
    from(
      u in "users",
      select: %{id: u.id, email: u.email, onboarded: u.onboarded, roles: u.roles}
    )

  Repo.transaction(
    fn ->
      query
      |> Repo.stream()
      |> Stream.each(fn user ->
        cond do
          user.onboarded && user.roles != nil && length(user.roles) > 1 ->
            roles = ["test"]

            user
            |> Repo.update_all(set: [roles: roles])

          true ->
            IO.puts("User #{user.email} has no roles. Onboarded: #{user.onboarded}")
        end
      end)
      |> Stream.run()
    end,
    timeout: :infinity
  )
end

以及我的模式:
schema "users" do
  field(:email, :string)
  field(:roles, {:array, :string})
  field(:onboarded, :boolean, default: false)
  field(:is_bot, :boolean, default: false)
end

我想通过使用u in "users",我可以避免在模型中遍历我的模式,但它似乎无论如何都在使用它。
错误:
** (Postgrex.Error) ERROR 42703 (undefined_column): column u0.is_bot does not exist
(db_connection) lib/db_connection.ex:1406: DBConnection.prepare_declare/4
(elixir) lib/stream.ex:1270: anonymous fn/5 in Stream.resource/3
(elixir) lib/stream.ex:1433: Enumerable.Stream.do_each/4
(elixir) lib/stream.ex:806: Stream.do_transform/8
(elixir) lib/stream.ex:1433: Enumerable.Stream.do_each/4
(elixir) lib/stream.ex:591: Stream.run/1
(ecto) lib/ecto/adapters/sql.ex:576: anonymous fn/3 in Ecto.Adapters.SQL.do_transaction/3
(db_connection) lib/db_connection.ex:1275: DBConnection.transaction_run/4

如何运行此迁移?

最佳答案

你在滥用移民的种子。您可能应该做的是将种子代码移到seeds/update_roles.exs中的某个位置,并使用此别名设置ecto向上(在mix.exs文件中):

defp aliases do
  [
    "ecto.setup": ["ecto.create", "ecto.migrate", "run seeds/update_roles.exs"],
    ...

这样,数据库将首先完全设置为现代版本,然后与数据一起播种。当前代码尝试使用包含is_bot字段的架构在尚未包含该字段的数据库上运行种子。

关于postgresql - 旧的ecto迁移无法运行,因为我在模型架构中添加了新字段,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/49269932/

10-11 03:01
查看更多