从数据库加载日期/时间类型时,Ecto将转换为Ecto.DateTime类型。从JSON字符串加载模型时,如何应用相同的类型转换
defmodule Rocket.User do
use Rocket.Model
schema "users" do
field :created_at, :datetime
field :name, :string
field :email, :string
field :password, :string
field :timezone, :string
end
end
iex(40)> Poison.decode!(~s({"created_at":"2015-01-21T06:05:10.891Z"}), as: Rocket.User)
%Rocket.User{created_at: "2015-01-21T06:05:10.891Z", email: nil, id: nil,
name: nil, password: nil, timezone: nil}
如果使用的是Ecto 0.6.0,最好的方法是使用变更集:
Ecto.Changeset.cast Poison.decode!(data), %Rocket.User{},
~w(required_fields), ~w(optional_fields)
如果您将其作为外部数据接收,则实际上建议使用变更集,因为在将其添加到模型之前,需要转换,过滤和验证该数据。您可以在Ecto简介和Ecto.Changeset
模块文档中找到有关它们的更多信息。
但是,还有一个问题:Ecto不知道如何将字符串转换为datetime。但是,您可以使用自定义类型教它如何操作。我在下面创建了一个模板,您只需要实现强制转换功能即可:
https://gist.github.com/josevalim/1ed574b388c32f056da1
然后在您的架构中:
timestamps type: Rocket.DateTime
您可以在Ecto.Type
文档中找到更多信息。我知道我们需要在Ecto中对此进行改进,我认为我们至少应该能够以JSON中指定的格式解析日期时间。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句