【问题标题】:Default case class parameter with lift-json带 lift-json 的默认案例类参数
【发布时间】:2013-07-09 05:48:51
【问题描述】:

基本场景:

case class Something(
    date: Option[Date],
    timestamp: Option[Date] = Some(new Date)
);

class Users private() extends MongoRecord[Users] with ObjectIdPk[Users] {
    def meta = Users;
    object things extends MongoCaseClassListField[Users, Something](this);
};


object Users extends Users with MongoMetaRecord[Users] {

};     

def something(json: JValue) = {
    val something = json.extract[Something];// does not have a timestamp field.
    decompose(something); // again no timestamp field.
    Users.where(_.email eqs email).findAndModify(_.things addToSet something).updateOne(true);
};

问题:当没有timestamp 字段的JSON 作为请求发送时,数据库条目根本没有timestamp 字段。

如果使用timestamp: Date 而不是timestamp: Option[Date],则JSON 提取会抛出MappingException

问:缺少的 JSON 字段/案例类参数如何默认为值?

【问题讨论】:

标签: mongodb scala lift


【解决方案1】:

我可能会尝试这样的事情:

case class Something(date: Option[Date], timestamp: Option[Date]){
  def this(date:Option[Date]) = this(date, Some(new Date))
}

这会创建一个单独的单参数构造函数,并将默认日期传递给双参数构造函数。通过 REPL 运行它,您可以看到时间戳似乎设置正确:

scala> parse(""" { "date":"2013-07-08T21:37:10Z" }  """)
res11: net.liftweb.json.JValue = JObject(List(JField(date,JString(2013-07-08T21:37:10Z))))

scala> res11.extract[Something]
res16: Something = Something(Some(Mon Jul 08 17:37:10 EDT 2013),Some(Mon Jul 08 17:43:52 EDT 2013))

scala> parse(""" {
     |   "date":"2013-07-08T21:37:10Z",
     |   "timestamp":"2013-07-08T21:37:10Z"
     | } """)
res14: net.liftweb.json.JValue = JObject(List(JField(date,JString(2013-07-08T21:37:10Z)), JField(timestamp,JString(2013-07-08T21:37:10Z))))

scala> res14.extract[Something]
res17: Something = Something(Some(Mon Jul 08 17:37:10 EDT 2013),Some(Mon Jul 08 17:37:10 EDT 2013))

【讨论】:

    猜你喜欢
    • 2017-11-11
    • 1970-01-01
    • 1970-01-01
    • 2014-10-07
    • 2011-11-08
    • 1970-01-01
    • 1970-01-01
    • 2013-05-27
    • 1970-01-01
    相关资源
    最近更新 更多