以下を使用して、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>
)
}
...
}