微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – 使用CSqlDataProvider排序的Yii CGridview

我正在使用CsqlDataProvider来构造CGridview我不能使用CActiveRecord,因为结果集很大并且引发了内存错误.列需要是可排序的.我该怎么做到这一点?

示例sql

$orders_query_raw = 'select  o.order_id, o.customer_name, o.customer_email, o.customer_advertiser, o.payment_method, o.created, o.last_updated, o.currency, o.currency_value, o.status, o.blinking, s.name, ot.text order_total, o.customer_id, op.product_id, o.phonebooking 
from `order` o, `order_total` ot, `order_status` s , order_product op  
where o.order_id = op.order_id and o.status = s.order_status_id and ot.order_id = o.order_id and s.language_id = '1' and ot.class = 'ot_total'  group by o.order_id'

sql dataprovider

    $dataProvider = new CsqlDataProvider($orders_query_raw, array(
        'totalItemCount'=>$count, // get from a count query
        'pagination'=>array(
            'pageSize'=>50,
        ),
    ));

和gridview

$this->widget('zii.widgets.grid.CGridView', array(
    'dataProvider' => $dataProvider,
    'id'=>'order-grid',
    'columns' => array(
        array(
            'header'=>'Order ID',
            'value'=>array($this, 'gridOrderId'),
            'type'=>'raw',
        ),
        array(
            'header'=>Yii::t('order', 'Customers'),
            'name'=>'customer.fullName',
            'value'=>'CHtml::link($data[\'customer_name\'], \'mailto:\'.$data[\'customer_email\'])',
            'type'=>'raw',
        ),
        array(
            'header'=>Yii::t('order', 'Order total'),
            'value'=>'strip_tags($data[\'order_total\'])',
            'type'=>'raw',
            'htmlOptions'=>array(
                'style'=>'text-align:right;',
            ),
        ),
        array(
            'header' => Yii::t('order', 'Date Purchased'),
            'name' => 'created',
        ),
        array(
            'header'=> Yii::t('order', 'Last modify date'),
            'value'=>array($this, 'gridLastModified'),
        ),
        array(
            'header' => Yii::t('order', 'Status changed by'),
            'value' => array($this, 'gridLastModifiedUserFirstName'),
        ),
        array(
            'header' => Yii::t('provider', 'Provider\'s code'),
            'value' => array($this, 'gridProviderCode'),
            'type' => 'raw',
            'htmlOptions'=>array(
                'class'=>'nobr',
            ),
        ),
        array(
            'header' => Yii::t('order', 'Follow up'),
            'value' => array($this, 'gridFollowUp'),
            'type' => 'raw',
        ),
        array(
            'header' => Yii::t('order', 'Order status'),
            'value' => '$data[\'name\']',
        ),
        array(
            'class'=>'CButtonColumn',
            'template'=>'{update}',
            'header'=>'Action',
            'buttons'=>array(
                'update'=>array(
                    'url'=>'Yii::app()->createUrl(\'order/update\', array(\'order_id\'=>$data[\'order_id\']))',
                ),
            ),
        ),
    ),
));

谢谢

解决方法:

要使用数据提供程序作为CsqlDataProvider在网格视图中启用排序(通过单击列的标题),您最少需要2件事:

>必须使用attributes that would be sortable为数据提供者定义CSort对象.
>必须定义name of the column,但仅在您指定grid-view的columns属性时,否则如果columns属性为空,则CSort对象中提到的任何属性都是可排序的.

也就是说,另一个答案应该适用于sql很简单的情况,来自1个表,但在你的情况下,sql有点复杂,即数据来自多个表,解决方案会略有改变.

在这种情况下,您必须考虑冲突的列名(如果有),以及CSort属性数组的正确规范.

例子:

>任何表中都没有冲突的列名(与其他答案相同):

$dataProvider=new CsqlDataProvider($sql, array(
    'totalItemCount'=>$count,
    'sort'=>array(
        'attributes'=>array(
            'order_id, order_total' // csv of sortable column names
        )
    )
));

然后在你的网格中:

array(
    'header'=>Yii::t('order', 'Order total'),
    'name'=>'order_total',// to make header clickable to sort
    'value'=>'strip_tags($data[\'order_total\'])',
    'type'=>'raw',
    'htmlOptions'=>array(
        'style'=>'text-align:right;',
    ),
),

>冲突的列名称

>首先,在sql中提供所有冲突的名称别名.
>其次,将这些别名指定为CSort对象中的可排序属性

'attributes'=>array(
    'some_alias, some_other_alias'
)

>在列中指定列的名称

array(
    'header'=>'Foo',
    'name'=>'some_alias',
    'value'=>'$data[\'some_alias\']' // this is actually redundant in this
    // case, because the name will itself pick up the value, and we don't
    // need to specify value explicitly if we are not applying any function to it
)

请注意,通过仅指定排序对象来启用按url调用进行排序,不需要使用名称,除非您要单击以对标题进行排序.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐