Как мне указать имя таблицы в фильтре в Yii? - PullRequest
3 голосов
/ 09 октября 2011

Есть две таблицы, attendee и group.оба имеют поле gender.Каждому участнику назначается 1 группа.У меня CGridView успешно показывает количество посетителей, но когда я добавил код для фильтрации по полу, я получаю следующую ошибку.Чтобы подсчитать количество участников в группе, я вручную выполняю объединение;но соединение делает поле «пол» неоднозначным.Есть ли способ указать в фильтре, что он должен использовать 't' или базовую таблицу?

Когда я загружаю представление, оно работает правильно;когда я нажимаю для сортировки на gender, мне выдается следующее сообщение:

Сообщение об ошибке

>     Error 500: <h1>CDbException</h1>
>     <p>CDbCommand failed to execute the SQL statement: SQLSTATE[23000]: Integrity constraint violation: 1052 Column 'gender'
> in where clause is ambiguous. The SQL statement executed was: SELECT
> COUNT(*) FROM (SELECT t.*, IFNULL( count(tbl_attendee.id), 0) as
> attendeeCount FROM `tbl_group` `t` LEFT JOIN tbl_attendee ON
> tbl_attendee.group_id = t.id WHERE gender LIKE :ycp0 GROUP BY t.id) sq
> (/Applications/MAMP/htdocs/yiiroot/framework/db/CDbCommand.php:516)</p><pre>#0
> /Applications/MAMP/htdocs/yiiroot/framework/db/CDbCommand.php(411):
> CDbCommand->queryInternal('fetchColumn', 0, Array)

Код модели

$criteria=new CDbCriteria;
$criteria->compare('name',$this->name,true);
$criteria->compare('gender',$this->gender,true);                
$criteria->compare('agegroup',$this->agegroup,true);
$criteria->select = 't.*, IFNULL( count(tbl_attendee.id), 0) as attendeeCount';
$criteria->join = 'LEFT JOIN tbl_attendee ON tbl_attendee.group_id = t.id';
$criteria->group = 't.id';

$sort = new CSort();
$sort->attributes = array(
    'attendeeCount'=>array(
    'asc'=>'attendeeCount ASC',
    'desc'=>'attendeeCount DESC',
    ),
    '*', // add all of the other columns as sortable
);

return new CActiveDataProvider($this, array(
'criteria'=>$criteria,
'sort'=>$sort,
));

Просмотреть код

$this->widget('zii.widgets.grid.CGridView', array(
    'id'=>'group-grid',
    'dataProvider'=>$model->search(),
    'filter'=>$model,
    'columns'=>array(
       'name',
       array(
        'name'=>'gender',
        'value'=>'Group::$genderLabels[$data->gender]',
        'filter'=>Group::$genderLabels, // <-- This is the filter that breaks.
                                        // $genderLabels = array('Female','Male);
    ),

1 Ответ

5 голосов
/ 09 октября 2011

Ах!Я понял.

Изменена эта строка в коде модели:

$criteria->compare('gender',$this->gender,true);

до

$criteria->compare('t.gender',$this->gender,true);

Найденоответ здесь.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...