6

我有一个从 CActiveDataProvider 提供的简单 CGridView。目前,我不确定这已经发生了多长时间,它不会在启用分页的视图中显示所有数据项。

我的标题显示“显示 9 个结果中的 1-7 个”,但没有更多页面的按钮。如果我将数据提供者的 pagenation 属性的 pageSize 设置为一个较小的数字,我最终将获得分页按钮,但它似乎在第一页上显示的项目比第二页少。例如,如果我将 CActiveDataProvider 的 pageSize 设置为 3,我会得到 2,2,3(每页上的项目),而不是我预期的 3,3,1。

如果我将 pageSize 设置为介于 9 和 11 之间的任何值(包括 9 和 11),则有些项目我看不到,因为我只看到一页并且并非所有项目都显示(如果我将 pageSize 设置为 9,则为“1-6 of 9”)。

$criteria=new CDbCriteria;
$criteria->with = array('registrations'); 
$criteria->addCondition('registrations.id IS NOT NULL');
$criteria->addCondition('registered = false');
$criteria->together = true;
$dataProvider = new CActiveDataProvider('Skier', array('criteria'=>$criteria));

$this->widget('zii.widgets.grid.CGridView', array(
    'dataProvider'=>$dataProvider,
    'columns'=>array(
        array('name'=>'fullname', 'header'=>'Name'),
        array(
            'name'=>'programs_names',
            'header'=>'Programs',
            'value'=>'$data->programs_names',
        ),
        <More items here>
    )
));

任何人都知道什么会导致分页如此不稳定?

编辑:此外,将 CActiveDataProvider 更改为 CArrayDataProvider 工作正常,我得到 9 个结果中的 9 个。这暂时可行,因为我的数据集很小,但我宁愿弄清楚问题可能是什么。

$dataProvider = new CArrayDataProvider(Skier::model()->findAll($criteria));
4

5 回答 5

1

我有这样的问题。这是由于数据库中的重复条目(主键)。

于 2013-12-08T18:49:22.690 回答
1

如果您使用的是复杂查询,请尝试此查询

$count=Yii::app()->db->createCommand('SELECT COUNT(*) FROM tbl_user')->queryScalar();

$sql='SELECT * FROM tbl_user';

$dataProvider=new CSqlDataProvider($sql, array(
    'totalItemCount'=>$count,
    'sort'=>array(
        'attributes'=>array(
             'id', 'username', 'email',
        ),
    ),
    'pagination'=>array(
        'pageSize'=>10,
    ),
));
// $dataProvider->getData() will return a list of arrays.

然后你可以将你的 $dataProvider 传递给你的 CGridView

有关使用自定义查询作为 dataProvider 的更多文档,请在此处查看。

于 2013-12-05T04:47:28.067 回答
1

我不得不把$criteria->withtogether=true放在一个里面if()

if( (int) $this->categoria_id > 0) {
    $criteria->with = Array (
        'categorie'=> Array (
            'together' => true,
        )
    );
    $criteria->compare ('categorie.id', $this->categoria_id);
}

否则CActiveDataProvider 分页没有together=true传递参数返回错误的计数

于 2016-04-02T10:28:22.633 回答
0

尝试将以下内容添加到“滑雪者”模型的搜索方法中:

$criteria->group = "id";

或者:

$criteria->group = "t.id";
于 2017-02-10T15:34:01.710 回答
0

例如,要准确显示所有记录,'count rows'然后'supply $countResult to pageSize'

首先计算行(这是一个示例,'User' = 'your model name'))

$countResult = User::model()->countByAttributes(array('record_name' => $matched_record_name));

或者

$countResult = User::model()->count($condition);

然后将 $countResult 提供给 pageSize

            'pagination'=>array(
                'pageSize' => intval($countResult),
                )), 
于 2016-02-17T00:39:55.017 回答