我正在使用 Elixir 从外部 API 检索 json 并将其存储在 Postgresql 数据库中。我正在使用 Poison 将 json 解码为 Elixir Ecto (2.0) 模式。它运行良好,除了一个方面:json 的一个元素是一个没有任何键的 List。我不知道如何将此元素映射到 Elixir 结构。
json:
{"name": "Joe Random"
"address": {
"street": "123 Main St",
"city": "Smalltown"
},
"interests": [
"Biking",
"Movies"
]
}
此 json 采用结构(人)的形式,具有嵌入式结构(地址)和嵌入式列表(兴趣)。我想用 Ecto.Schemas 对这个结构进行建模,以便将 json 加载到其中。person 和 address 结构很简单:
defmodule Person do
use Ecto.Schema
schema "person" do
field :name, :string
embeds_one :address, Address
end
end
defmodule Address do
use Ecto.Schema
embedded_schema do
field :street, :string
field :city, :string
end
end
我可以使用 Poison.decode 来加载这些结构:
Poison.decode!(json, as person: %Person{address: %Address{}})
但是,我如何建模和存储“兴趣”:来自 json?它只是一个没有任何键的简单单值列表。我可以把它变成一张地图,然后我可以用 Ecto.Schema 建模吗?有没有人遇到过这样的问题?
任何指导将不胜感激!