我正在尝试通过 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)
我从中得到Empty
,S.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>
)
}
...
}