defaultOrder contengono un array dove key è un nome di colonna e value è un SORT_DESC
o SORT_ASC
ecco perché sotto il codice non funziona.
$dataProvider = new ActiveDataProvider([
'query' => $query,
'sort' => ['defaultOrder'=>'topic_order asc']
]);
modo corretto
$dataProvider = new ActiveDataProvider([
'query' => $query,
'sort' => [
'defaultOrder' => [
'topic_order' => SORT_ASC,
]
],
]);
Nota: Se una query specifica già la clausola orderBy, le nuove istruzioni di ordinazione forniti dagli utenti finali (attraverso la configurazione di sorta) verrà aggiunto al orderBy esistente clausola. Eventuali limiti esistenti e clausole di compensazione verranno sovrascritte dalla richiesta di impaginazione da parte degli utenti finali (tramite la configurazione di impaginazione).
È possibile dettaglio imparare da Yii2 Guide of Data Provider
Ordinamento Passando oggetto Ordina nella query
$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();
fonte
2016-05-10 13:09:07
Questa soluzione funziona ma la ricerca nell'indice non funziona ora –