Maison >cadre php >YII >Comment trier les tables yii2.0

Comment trier les tables yii2.0

尚
original
2019-12-09 13:37:132420parcourir

Comment trier les tables yii2.0

Dans le développement actuel des projets Yii2.0, nous rencontrons souvent l'utilisation de la fonction de tri fournie avec Yii2.0.

Lors de l'affichage de plusieurs éléments de données, il est généralement nécessaire de trier les données en fonction des colonnes spécifiées par l'utilisateur. Yii utilise l'objet yiidataSort pour représenter des informations sur le schéma de tri. En particulier :

1. attributs précise les attributs selon lesquels les données sont triées. Un attribut peut être un simple attribut de modèle ou un attribut composite qui combine plusieurs attributs de modèle ou colonnes de base de données. Plus de détails sont donnés ci-dessous.

2.attributOrders donne le sens de tri actuellement défini pour chaque attribut.

3. commandes donne le sens de tri sous forme de colonnes de bas niveau.

Pour utiliser yiidataSort, vous devez d'abord déclarer quels attributs peuvent être triés. Obtenez ensuite les informations de tri actuellement définies à partir des attributsOrders ou des commandes, puis utilisez-les pour personnaliser les requêtes de données.

(Apprentissage recommandé : cadre yii )

Voici la méthode spécifique d'utilisation de la fonction de tri :

1. Définissez les règles de tri <.>

Faites attention à l'introduction de la classe Sort, par exemple : utilisez yiidataSort;

// 设置排序字段
        $sortObject = new Sort([
                &#39;sort&#39; => $sort,
                &#39;defaultOrder&#39; => [&#39;id&#39; => SORT_DESC],
                &#39;attributes&#39; => [
                        &#39;id&#39; => [
                                &#39;asc&#39; => [&#39;id&#39; => SORT_ASC],
                                &#39;desc&#39; => [&#39;id&#39; => SORT_DESC],
                        ],
                        &#39;user_name&#39; => [
                                &#39;asc&#39; => [&#39;ecs_users.user_name&#39; => SORT_ASC],
                                &#39;desc&#39; => [&#39;ecs_users.user_name&#39; => SORT_DESC],
                        ],
                        &#39;add_time&#39; => [
                                &#39;asc&#39; => [&#39;add_time&#39; => SORT_ASC],
                                &#39;desc&#39; => [&#39;add_time&#39; => SORT_DESC],
                        ],
                ],
        ]);

2 Utilisez la fonction de pagination de Yii2.0 et ajoutez le tri

// 处理分页
        $queryClone = clone $query;
        $totalCount = $queryClone->count();
        $pages = new Pagination([&#39;defaultPageSize&#39;=>$rows,&#39;totalCount&#39;=>$totalCount,&#39;pageSizeLimit&#39;=>false]);
        $query = $query->offset($offset)
                       ->limit($pages->limit)
                       ->orderBy($sortObject->orders)
                       ->asArray()
                       ->all();

3. Modifier le code sous-jacent du tri Yii2.0

Le code source correspondant sous-jacent : supplier/yiisoft/yii2.0/data/Sort.php

1 Ajouter un attribut à la classe Sort : public $sort;

2. Dans le code source approx. Ajoutez le code suivant à la ligne 249 : (implémentez post pour obtenir les paramètres de pagination)

  // get请求获取数组为空,则调用自定义属性sort。用于满足post获取后处理自定义参数
 if(!isset($params[$this->sortParam])){
    $params[$this->sortParam] = $this->sort;
  }

3. Recevez les paramètres de pagination dans le contrôleur, comme suit :

$sort = $_POST[&#39;sort&#39;] ? strval($_POST[&#39;sort&#39;]) : &#39;id&#39;;
$sort = $_POST[&#39;order&#39;] == &#39;asc&#39; ? $sort : &#39;-&#39;.$sort;

Remarque : L'identifiant dans Yii2.0 représente la valeur correcte en fonction de l'identifiant. Tri dans l'ordre, -id signifie trier dans l'ordre inverse par identifiant. C'est également la raison pour laquelle la déclaration 2 ci-dessus est traitée de cette manière.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn