1

我正在尝试通过 id 从 MongoDB 中查找值:

var id = S.param("id") openOr ""
val qry = QueryBuilder.start("id").is(id).get
def render = {
    val items = Delegacja.findAll(qry)   

    ".my_list *" #> items.map(e => 
      ".my_list_item" #> <li>{e.gdzie_od1}</li> &
      ".my_list_item_id" #> <li>{e.id}</li>
    )
}

模型:

package code.model
import _root_.net.liftweb.record.field._
import net.liftweb.mongodb.record._
import net.liftweb.mongodb.record.field.ObjectIdPk

class Delegacja private() extends MongoRecord[Delegacja] with ObjectIdPk[Delegacja]{
  def meta = Delegacja

  object gdzie_od1 extends StringField(this, 30)
  object gdzie_do1 extends StringField(this, 30)
  object data_od1 extends StringField(this, 500)
  object data_do1 extends StringField(this, 500)
}

object Delegacja extends Delegacja with MongoMetaRecord[Delegacja]

或只是val items = Delegacja.find("Id" -> id)val items = Delegacja.find("Id" -> id.toString)val items = Delegacja.find("id", id)没有发现,ID 很好,当我按某个名称查找时它可以,但按 id 没有结果。有人可以告诉我我做错了什么吗?


嗯,我想有一些线索。(而且真的find改变id_id;))

当我在做:

val md1 = Delegacja.createRecord.gdzie_od1(gdzie_od1).gdzie_do1(gdzie_do1).save
S.notice(md1.id.is.toString)
val md = Delegacja.find("_id", md1.id.is.toString)
S.notice(md.is.toString)

我从中得到EmptyS.notice(md.is.toString)但是当我更改val md = Delegacja.find("_id", md1.id.is.toString)为没问题时val md = Delegacja.find("_id", md1.id.is)viewitem.scala我需要以某种方式将string ( id )我从链接中获得的参数转换为oibjectid,如何处理它?

class ViewItem {

  var id = S.param("id") openOr ""
          val qry = QueryBuilder.start("_id").is(id).get
  def render = {

    val items = Delegacja.find("_id", id) // THIS id.ToObjectIdPK some how ..
     S.notice(items.toString)

    ".my_list *" #> items.map(e => 
      ".my_list_item" #> <li>{e.gdzie_od1}</li> &
      ".my_list_item_id" #> <li>{e.id}</li>
    )
  }
...
}
4

1 回答 1

1

Ah mean while I get answer:

need new import:

import org.bson.types.ObjectId

And :

 val items = Delegacja.find("_id", new ObjectId(id))

This is the needed conersion ;]

于 2012-09-24T08:11:03.420 回答