我正在使用GridView显示一些数据。我需要按以下2列添加默认排序:
(CASE
WHEN (inbound_datetime IS NULL AND outbound_datetime < NOW()) OR (inbound_datetime IS NOT NULL AND inbound_datetime < NOW())
THEN 9999
WHEN (inbound_datetime IS NOT NULL AND outbound_datetime < NOW())
THEN inbound_datetime
ELSE outbound_datetime
END) ASC如果我将此代码添加到数据提供程序查询中的ORDER BY子句中,那么所有其他排序选项都无法工作,因为此条件已应用于查询本身。
我尝试将默认排序应用于任何其他网格,但它不起作用(该方法搜索具有该名称的属性):
'sort' => [
'defaultOrder' => [
'(CASE
WHEN (inbound_datetime IS NULL AND outbound_datetime < NOW()) OR (inbound_datetime IS NOT NULL AND inbound_datetime < NOW())
THEN 9999
WHEN (inbound_datetime IS NOT NULL AND outbound_datetime < NOW())
THEN inbound_datetime
ELSE outbound_datetime
END)' => SORT_ASC,
],
],是否有任何方法使此默认排序工作,并仍然能够保持正确使用网格排序的列名?
发布于 2016-01-29 09:29:00
我做了更多的思考,并想出了解决这个问题的办法。
我在我的控制器方法中定义了查询,它打开视图。因此,我添加了一个条件,检查排序参数是否传递给get请求。如果它被传递,我将在没有ORDER BY子句的情况下创建查询。如果未传递排序参数(不执行列排序),则使用ORDER BY子句创建查询。在我的控制器方法中:
if (Yii::$app->request->get('sort')) {
$query = Travel::find();
} else {
$query = Travel::find()
->orderBy('(CASE
WHEN (inbound_datetime IS NULL AND outbound_datetime < NOW()) OR (inbound_datetime IS NOT NULL AND inbound_datetime < NOW())
THEN 9999
WHEN (inbound_datetime IS NOT NULL AND outbound_datetime < NOW())
THEN inbound_datetime
ELSE outbound_datetime
END) ASC');
} https://stackoverflow.com/questions/35080592
复制相似问题