我正在实现与quickstart guide完全相同的模型。
在我的模型中,我正在尝试实现findByToken()
方法。当前的find()
方法接受$id
参数,但我想查找不同列的值。
//excerpt from the quickstart guide
public function find($id, Default_Model_Guestbook $guestbook)
{
$result = $this->getDbTable()->find($id);
if (0 == count($result)) {
return;
}
$row = $result->current();
$guestbook->setId($row->id)
->setEmail($row->email)
->setComment($row->comment)
->setCreated($row->created);
}
我尝试过做这样的事情,但我觉得它不起作用:
$db = $this->getDbTable();
$where = $db->getAdapter()->quoteInto('token = ?', $token);
$result = $db->find($where);
通过指定列的值查找行的正确方法是什么?
答案 0 :(得分:8)
$result = $db->fetchAll($where);
或者如果您只想检索一行。
$result = $db->fetchRow($where);
你也可以使用Zend_Db_Select对象,保持适配器进一步抽象化:
$db = $this->getDbTable();
$select = $db->select()->where('token = ?', $token);
$result = $db->fetchAll($select);
答案 1 :(得分:4)
这可以通过创建选择对象并使用此对象获取行来轻松完成。它在手册中有详细描述:http://framework.zend.com/manual/en/zend.db.select.html#zend.db.select.execute
您的代码可能如下所示:
$select = $this->getDbTable()->select()->where('token = ?', (string) $token);
$row = $this->getDbTable()->fetchRow($select);