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);

または、1 行だけを取得しようとしている場合。

$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 に答える