Zend Framework: Как найти строку таблицы по значению указанного столбца? - PullRequest
4 голосов
/ 16 декабря 2009

Я реализую свою модель в точности как руководство по быстрому запуску .

В моей модели я пытаюсь реализовать метод 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);

Как правильно найти строку по значению указанного столбца?

Ответы [ 2 ]

8 голосов
/ 16 декабря 2009
$result = $db->fetchAll($where);

или если вы пытаетесь получить только одну строку.

$result = $db->fetchRow($where);

Вы также можете использовать объект Zend_Db_Select, оставляя адаптер немного дальше:

$db = $this->getDbTable();
$select = $db->select()->where('token = ?', $token);
$result = $db->fetchAll($select);
4 голосов
/ 16 декабря 2009

Это легко сделать, создав объект select и извлекая строку, используя этот объект Это хорошо описано в руководстве: 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);
...