如何使用lift-json的类提取器构造函数mongo bson数组?

时间:2016-03-19 03:10:57

标签: mongodb lift

我使用lift-json使用类提取器渲染bson字符串,然后使用mongo Document类构造函数将该文档实例与该bson字符串一起使用。

问题是如何表示$or bson。它似乎不是经典的json数组。

 {"$or": [
      {"username": "administrator"},
      {"phone":"110"},
      {"email":"123@xxx.com"},
      {"pen_name":"lorancechen"}
 ]}

如何使用lift类提取器代表这个bson数组?

此外,在app和mongo之间使用字符串的原因是它们是在一个简单的套接字下进行通信。

更新添加示例
提取器是一个正常的数组类,如下所示:

import net.liftweb.json._
import net.liftweb.json.Extraction._

case class Name(name: String)
case class JsonArray(array:List[Name])

object JsonClient extends App {
  implicit val formats = DefaultFormats

  val names = Name("jone01") :: Name("jone02") :: Nil
  val array = JsonArray(names)
  val jsonString = prettyRender(decompose(array))
  println(jsonString)
}

输出:

{
  "array":[
    {
      "name":"jone01"
    },
    {
      "name":"jone02"
    }
  ]
}

如何表示

{"$or": [
      {"username": "administrator"},
      {"phone":"110"},
      {"email":"123@xxx.com"},
      {"pen_name":"lorancechen"}
 ]}

元素内部的每个字段键(例如usernamephone)" $或"不是常用的关键名称,我还没有找到一种方法来表示它使用类模板。

1 个答案:

答案 0 :(得分:0)

我不明白为什么你的JSON结构是这样的,也许你想要的是以下一个:

{
  "$or": [
    {
      "username": "administrator", "phone":"110",  
      "email":"123@xxx.com", "pen_name":"lorancechen"
    },
    {
      "username": "xxx", "phone":"xxx",  
      "email":"xxx", "pen_name":"xxx"
    }
    ...
  ]
}

实际上Lift提供了这样的工具,缺点是实现有点难看。

  import net.liftweb.mongodb.{JsonObjectMeta, JsonObject}

  // the trait here is for unifying the type of 
  //four case classes i.e Username, Phone....
  sealed trait PersonField

  object Username extends JsonObjectMeta[Username]
  case class Username(username: String) extends JsonObject[Username] 
     with PersonField {
     def meta = Username
  }

  case class Phone(phone: String) extends JsonObject[Phone] with PersonField {
     def meta = Phone
  }
  object Phone extends JsonObjectMeta[Phone]

  case class Email(email: String) extends JsonObject[Email] with PersonField {
     def meta = Email
  }
  object Email extends JsonObjectMeta[Email]

  case class PenName(pen_name: String) extends JsonObject[PenName] 
     with PersonField {
     def meta = PenName
  }
  object PenName extends JsonObjectMeta[PenName]

  case class Output(`$or`: List[PersonField]) extends JsonObject[Output] {
    def meta = Output
  }

  object Output extends JsonObjectMeta[Output]


  object JsonClient extends App {

     val username = Username("administrator")
     val phone = Phone("110")
     val email = Email("123@xxx.com")
     val penName = PenName("lorancechen")
     val outPut = Output(username :: phone :: email :: penName :: Nil)

     import net.liftweb.json._
     implicit val formats = DefaultFormats

     import net.liftweb.json.{JsonAST, Printer}
     val result = Printer.pretty(JsonAST.render(outPut.asJObject))

     /*
        {
          "$or":[{
            "username":"administrator"
          },{
            "phone":"110"
          },{
            "email":"123@xxx.com"
          },{
            "pen_name":"lorancechen"
          }]
        }

     */
     println(result)
  }

无论如何,希望它有所帮助。