4

我正在实现我的模型,就像快速入门指南一样。

在我的模型中,我正在尝试实现一种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);

通过指定列的值查找行的正确方法是什么?

4

2 回答 2

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);
于 2009-12-16T00:54:28.900 回答
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);
于 2009-12-16T00:56:18.193 回答