Yii 1.1에서이 코드는 기본 정렬을 위해 작동합니다.
$dataProvider = new CActiveDataProvider('article',array(
'sort'=>array(
'defaultOrder'=>'id DESC',
),
));
Yii2에서 기본 정렬을 어떻게 설정할 수 있습니까?
아래 코드를 시도했지만 결과가 없습니다.
$dataProvider = new ActiveDataProvider([
'query' => $query,
'sort' => ['defaultOrder'=>'topic_order asc']
]);
답변
적절한 해결책이 있다고 생각합니다. yii\data\Sort
개체 구성 :
$dataProvider = new ActiveDataProvider([
'query' => $query,
'sort'=> ['defaultOrder' => ['topic_order' => SORT_ASC]],
]);
답변
또는
$dataProvider->setSort([
'defaultOrder' => ['topic_order'=>SORT_DESC],
'attributes' => [...
답변
defaultOrder는 키가 열 이름과 값이있는 배열이 포함 SORT_DESC
또는 SORT_ASC
코드 아래에 작동하지 않는 이유의를.
$dataProvider = new ActiveDataProvider([
'query' => $query,
'sort' => ['defaultOrder'=>'topic_order asc']
]);
올바른 방법
$dataProvider = new ActiveDataProvider([
'query' => $query,
'sort' => [
'defaultOrder' => [
'topic_order' => SORT_ASC,
]
],
]);
참고 : 쿼리가 이미 orderBy 절을 지정하는 경우 최종 사용자가 제공 한 새 순서 지정 지침 (정렬 구성을 통해)이 기존 orderBy 절에 추가됩니다. 기존 제한 및 오프셋 절은 최종 사용자의 페이지 매김 요청 (페이지 매기기 구성을 통해)에 의해 덮어 쓰여집니다.
Yii2 데이터 제공자 가이드 에서 자세히 배울 수 있습니다.
쿼리에서 Sort 개체를 전달하여 정렬
$sort = new Sort([
'attributes' => [
'age',
'name' => [
'asc' => ['first_name' => SORT_ASC, 'last_name' => SORT_ASC],
'desc' => ['first_name' => SORT_DESC, 'last_name' => SORT_DESC],
'default' => SORT_DESC,
'label' => 'Name',
],
],
]);
$models = Article::find()
->where(['status' => 1])
->orderBy($sort->orders)
->all();
답변
CRUD (인덱스)가 있고 GridView 또는 ListView 등에 대한 컨트롤러의 기본 정렬을 설정해야하는 경우 … 예
public function actionIndex()
{
$searchModel = new NewsSearch();
$dataProvider = $searchModel->search(Yii::$app->request->queryParams);
// set default sorting
$dataProvider->sort->defaultOrder = ['id' => SORT_DESC];
return $this->render('index', [
'searchModel' => $searchModel,
'dataProvider' => $dataProvider,
]);
}
당신은 추가가 필요합니다
$dataProvider->sort->defaultOrder = ['id' => SORT_DESC];
답변
이것을 시도하십시오
$dataProvider = new ActiveDataProvider([
'query' => $query,
]);
$sort = $dataProvider->getSort();
$sort->defaultOrder = ['id' => SORT_ASC];
$dataProvider->setSort($sort);
답변
$dataProvider = new ActiveDataProvider([
'query' => $query,
'sort'=> ['defaultOrder' => ['iUserId'=>SORT_ASC]]
]);
답변
다음과 같이 검색 모델을 수정할 수 있습니다.
$dataProvider = new ActiveDataProvider([
'query' => $query,
'sort' => [
'defaultOrder' => ['user_id ASC, document_id ASC']
]
]);
