defaultOrder enthalten ein Array , in dem Schlüssel ist ein Spaltenname und Wert ist ein SORT_DESC
oder Aus SORT_ASC
diesem Grund unter Code funktioniert nicht.
$dataProvider = new ActiveDataProvider([
'query' => $query,
'sort' => ['defaultOrder'=>'topic_order asc']
]);
Der richtige Weg
$dataProvider = new ActiveDataProvider([
'query' => $query,
'sort' => [
'defaultOrder' => [
'topic_order' => SORT_ASC,
]
],
]);
Hinweis: Wenn in einer Abfrage bereits die orderBy-Klausel angegeben ist, werden die neuen Bestellanweisungen der Endbenutzer (über die Sortierkonfiguration) an die vorhandene orderBy-Klausel angehängt. Bestehende Limit- und Offset-Klauseln werden durch die Paginierungsanforderung der Endbenutzer (über die Paginierungskonfiguration) überschrieben.
Weitere Informationen finden Sie im
Yii2-Handbuch des Datenanbieters
Sortieren Durch Übergeben des Sortierobjekts in der Abfrage
$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();