3

使用以下混合部门:

[{:phoenix, "~> 0.15"},
 {:phoenix_ecto, "~> 1.0.0"},
 {:postgrex, ">= 0.0.0"},
 {:phoenix_html, "~> 2.1"},
 {:phoenix_live_reload, "~> 0.5", only: :dev},
 {:cowboy, "~> 1.0"}]

以及以下型号:

# foo.ex
has_many: :bars, App.Bar

# bar.ex
belongs_to: :foo, App.Foo

尝试预加载时出现错误bars,当 aFoo已插入数据库时​​:

Repo.all(Foo) |> Repo.preload(:bars)

产量:

** (FunctionClauseError) no function clause matching in Postgrex.Extensions.Binary.encode/4
    (ecto) lib/ecto/repo/preloader.ex:49: Ecto.Repo.Preloader.do_preload/4

当尚未插入no 时,它不会产生错误(只是[]) 。Foo

Bar移民 :

defmodule App.Repo.Migrations.CreateBar do
  use Ecto.Migration

  def change do
    create table(:bars) do
      add :title, :string
      add :foo_id

      timestamps
    end

    create index(:bars, [:foo_id])
  end
end
4

1 回答 1

3

您缺少:foo_id迁移中的类型。

尝试以下操作:

defmodule App.Repo.Migrations.CreateBar do
  use Ecto.Migration

  def change do
    create table(:bars) do
      add :title, :string
      add :foo_id, references(:foos)

      timestamps
    end

    create index(:bars, [:foo_id])
  end
end

您可以在http://hexdocs.pm/ecto/0.15.0/Ecto.Migration.html阅读迁移文档

于 2015-08-12T13:10:33.960 回答