使用以下混合代表:
[{: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
时,如果已在数据库中插入Foo
,则会出错:
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
如果尚未插入[]
,则不会产生错误(仅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
答案 0 :(得分: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
阅读有关迁移的文档