Elixir Ecto:如何使用belongs_to和has_many编写迁移?

时间:2017-02-09 13:17:26

标签: postgresql elixir phoenix-framework ecto

我有两个modelsPersonPet,我希望Person能够have many个宠物,但Pet } belong to只有一个人:

defmodule MyApp.Person do
  use MyApp.Web, :model

  alias MyApp.Pet

  schema "persons" do
    field :name, :string
    has_many :pets, Pet
    timestamps()
  end

  def changeset(struct, params \\ %{}) do
    struct
    |> cast(params, [])
    |> validate_required([])
  end
end

defmodule MyApp.Pet do
  use MyApp.Web, :model

  alias MyApp.Person

  schema "pets" do
    field :name, :string
    belongs_to :person, Person
    timestamps()
  end

  def changeset(struct, params \\ %{}) do
    struct
    |> cast(params, [])
    |> validate_required([])
  end
end

那么,我该怎么写migration呢?

defmodule Iloveproblems.Repo.Migrations.CreatePersonsAndPets do
  use Ecto.Migration

  def change do
    create table(:persons) do
      add :name, :string
      # I don't know :( . The has_many stuff
      timestamps()
    end

    create table(:pets) do
      add :name, :string
      # I don't know :( . The belongs_to stuff
      timestamps()
    end
  end
end

我正在使用Postgres

提前致谢!

1 个答案:

答案 0 :(得分:10)

我想我会在这里发表评论。

为了创建一个用作外键的字段,您可以编写如下内容:

add :person_id, references(:persons), null: false

这确保该字段不为空(并非总是必要),并且它不会破坏参照完整性。