簡體   English   中英

Yii CGridview使用CSqlDataProvider排序

[英]Yii CGridview sorting with CSqlDataProvider

我正在使用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件事:

  1. 必須為數據提供程序定義CSort對象,並使用可排序attributes
  2. 必須定義name的列 ,但只有在情況下,您指定的columns網格視圖的屬性,否則如果列屬性是空白,什么屬性在CSort對象提到的將是排序。

也就是說,另一個答案應該適用於sql很簡單的情況,來自1個表,但在你的情況下,sql有點復雜,即數據來自多個表,解決方案會略有改變。

在這種情況下,您必須考慮沖突的列名(如果有),以及CSort attributes數組的正確規范。

例子:

  • 任何表中都沒有沖突的列名(與其他答案相同):

     $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;', ), ), 
  • 沖突的列名稱:

    1. 首先,在sql中提供所有沖突的名稱別名。
    2. 其次,將這些別名指定為CSort對象中的可排序attributes

       'attributes'=>array( 'some_alias, some_other_alias' ) 
    3. 指定name的列columns

       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調用進行排序,不需要使用name ,除非您要單擊以對標題進行排序

請嘗試以下方式

    $sort = new CSort();
    $sort->defaultOrder = 'order_id'; // for initial order
    $sort->attributes = array(
        'created'
    );
$dataProvider = new CSqlDataProvider($orders_query_raw, array(
    'totalItemCount'=>$count, // get from a count query
    'pagination'=>array(
        'pageSize'=>50,
    ),
    'sort'=>$sort
));

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM