Zend Framework Отношения - findDependentRowset - PullRequest
1 голос
/ 18 мая 2010

Когда я вызываю метод findDependentRowset, возвращаемый набор строк содержит все строки в зависимой таблице, а не только наборы строк, соответствующие ссылке.

Надеясь, что кто-нибудь может объяснить это, поскольку я предполагал, что findDependentRowset вернет только набор строк, соответствующий моему «правилу»?

У меня есть следующие модели DbTable:

class Model_DbTable_Advertisement extends Zend_Db_Table_Abstract
{
    protected $_name = 'Advertisements';
    protected $_primary = 'Id';

    protected $_dependentTables = array (
        'Model_DbTable_Image',
    );
}

class Model_DbTable_Image extends Zend_Db_Table_Abstract
{
    protected $_name = 'Images';
    protected $_primary = 'Id';

    protected $_referenceMap = array(
        'Images' => array(
            'column' => 'AdvertisementId',
            'refColumn' => 'Id',
            'refTableClass' => 'Model_DbTable_Advertisement',
        )
    );

}

Теперь, когда я выполню следующее: (Упрощено ради вопроса)

$model = new Model_DbTable_Advertisement();
$rowSet = $model->fetchAll();
$row = $rowSet->current();
$dRow = $row->findDependentRowset('Model_DbTable_Image');

Я ожидал бы, что $ dRow будет содержать только «Изображения» с тем же идентификатором AdvertisingId, что и $ row, но вместо этого я получу все строки в таблице Images.

1 Ответ

4 голосов
/ 24 июня 2010

Документация, кажется, говорит, что вы, возможно, неправильно называете некоторые элементы в вашей справочной карте для второй таблицы. Посмотрите, заменяет ли ключи 'column' и 'refColumn' на 'columns' и 'refColumns', а затем помещает строковые значения в одноэлементные массивы.

Подробнее см. http://framework.zend.com/manual/en/zend.db.table.relationships.html#zend.db.table.relationships.defining

...