Maison base de données SQL [SQL Learning] La connexion entre l'index ordonné et l'ordre par

[SQL Learning] La connexion entre l'index ordonné et l'ordre par

Apr 18, 2019 am 10:43 AM
order by sql

Généralement, il existe deux façons d'implémenter l'ordre par. La première consiste à utiliser l'index ordonné pour l'implémenter automatiquement. L'autre consiste à trier les résultats après les avoir sélectionnés. L'utilisation d'un index ordonné est bien sûr la plus rapide, mais il y a quelques restrictions. Jetons un coup d'œil au test ci-dessous.

Données de test : La table student a deux champs id et sid, id est la clé primaire. Il existe un total de 20W d'enregistrements, avec des identifiants allant de 1 à 200 000 et des sid allant également de 1 à 200 000.

La première situation :

Le champ order by n'est ni dans la condition Where ni dans la sélection

sélectionnez sid dans zhuyuehua.student où sid
[SQL Learning] La connexion entre lindex ordonné et lordre par

Deuxième cas :

commande par Le champ est pas dans la condition Where mais dans la sélection.

sélectionnez l'identifiant, le sid de zhuyuehua.student où sid
[SQL Learning] La connexion entre lindex ordonné et lordre par

Troisième cas :

Le champ order by est dans la condition Where mais pas dans la sélection.

sélectionnez sid dans zhuyuehua.student où sid
[SQL Learning] La connexion entre lindex ordonné et lordre par

La quatrième situation :

Le champ order by est dans la condition Where mais pas dans la sélection. Trier dans l'ordre inverse
Le champ de tri par n'est pas dans la condition Where et n'est pas dans la sélection Il y a une opération de tri

Le champ de order by n'est pas dans la condition Where mais est dans Select Il y a une opération de tri [SQL Learning] La connexion entre lindex ordonné et lordre par
Le champ de tri par est dans la condition Where mais pas dans la sélection Pas d'opération de tri

Le champ de order by est dans la condition Where mais pas dans le select (ordre inverse) Pas d'opération de tri

Conclusion :


Lorsque le champ order by apparaît dans la condition Where, l'index sera utilisé sans opération de tri.
Dans les autres cas, order by n'effectuera pas d'opérations de tri.

Analyse :


Pourquoi seulement lorsque le champ order by apparaît dans la condition Where, l'index de ce champ est utilisé pour éviter le tri. Il s'agit de la façon dont la base de données obtient les données dont nous avons besoin.
Un SQL peut en fait être divisé en trois étapes.

1. Obtenir des données
2.
3. Renvoyez les données traitées

Par exemple, l'instruction ci-dessus sélectionne sid de zhuyuehua.student où sid
Étape 1 : générer une exécution en fonction de la condition Where et des informations statistiques Planifiez, obtenez des données.

Étape 2 : Triez les données obtenues.


Lors de l'exécution du traitement des données (order by), la base de données vérifiera d'abord le plan d'exécution de la première étape pour voir si le champ order by utilise un index dans le plan d'exécution. Si tel est le cas, vous pouvez utiliser l'ordre d'indexation pour obtenir directement les données triées.
Sinon, opération de tri.

Étape 3 : Renvoyez les données triées.

Aussi :
Le tri des 50 000 données ci-dessus n'a pris que 25 ms. Peut-être pensez-vous que le tri ne prend pas beaucoup de ressources. Cependant, étant donné que les données du tableau ci-dessus sont ordonnées, le tri prend moins de temps. S'il s'agit d'une table relativement désordonnée, le temps de tri augmentera considérablement. De plus, les opérations de tri sont généralement effectuées en mémoire, ce qui représente une sorte de consommation de CPU pour la base de données. En raison des performances améliorées du CPU, le tri ordinaire de dizaines ou de centaines d'enregistrements n'aura pas un grand impact sur le système. . Mais lorsque votre jeu d'enregistrements atteint plus d'un million d'enregistrements, vous devez faire attention à savoir si vous devez le faire. Le tri de grands jeux d'enregistrements augmente non seulement la surcharge du processeur, mais peut également entraîner un tri du disque dur en raison d'une mémoire insuffisante. le disque dur se produit. Les performances chutent considérablement lors du tri.
Remarque : ORACLE ou DB2 disposent d'un espace pour les opérations de SORT (le tri de la mémoire mentionné ci-dessus). Par exemple, dans ORACLE, il s'agit de la zone globale utilisateur (UGA), qui contient les paramètres de paramètres tels que SORT_AREA_SIZE. Si la quantité de données à trier est importante, un débordement de tri (tri du disque dur) se produira et les performances seront considérablement réduites.

Résumé :




Lorsque les champs classés par apparaissent dans la condition Where, l'index sera utilisé sans tri. Pour être plus précis, les champs classés par sont dans le plan d'exécution. Lors de l’utilisation d’index, aucune opération de tri n’est requise.



Cette conclusion est valable non seulement pour le tri par, mais également pour d'autres opérations qui nécessitent un tri. Par exemple, regrouper par, union, distinct, etc.

Si vous souhaitez en savoir plus sur SQL, veuillez faire attention au site Web PHP chinois Tutoriel vidéo SQL !


  • [SQL Learning] La connexion entre lindex ordonné et lordre par
  • Taille : 16 Ko
  • [SQL Learning] La connexion entre lindex ordonné et lordre par
  • Taille : 16 Ko
  • [SQL Learning] La connexion entre lindex ordonné et lordre par
  • Taille : 20,6 Ko
  • [SQL Learning] La connexion entre lindex ordonné et lordre par
  • : 21 Ko

    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 de ce site Web
    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

    Outils d'IA chauds

    Undresser.AI Undress

    Undresser.AI Undress

    Application basée sur l'IA pour créer des photos de nu réalistes

    AI Clothes Remover

    AI Clothes Remover

    Outil d'IA en ligne pour supprimer les vêtements des photos.

    Undress AI Tool

    Undress AI Tool

    Images de déshabillage gratuites

    Clothoff.io

    Clothoff.io

    Dissolvant de vêtements AI

    AI Hentai Generator

    AI Hentai Generator

    Générez AI Hentai gratuitement.

    Article chaud

    R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
    1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Meilleurs paramètres graphiques
    1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
    Will R.E.P.O. Vous avez un jeu croisé?
    1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

    Outils chauds

    Bloc-notes++7.3.1

    Bloc-notes++7.3.1

    Éditeur de code facile à utiliser et gratuit

    SublimeText3 version chinoise

    SublimeText3 version chinoise

    Version chinoise, très simple à utiliser

    Envoyer Studio 13.0.1

    Envoyer Studio 13.0.1

    Puissant environnement de développement intégré PHP

    Dreamweaver CS6

    Dreamweaver CS6

    Outils de développement Web visuel

    SublimeText3 version Mac

    SublimeText3 version Mac

    Logiciel d'édition de code au niveau de Dieu (SublimeText3)

    Quelle est la différence entre HQL et SQL dans le framework Hibernate ? Quelle est la différence entre HQL et SQL dans le framework Hibernate ? Apr 17, 2024 pm 02:57 PM

    HQL et SQL sont comparés dans le framework Hibernate : HQL (1. Syntaxe orientée objet, 2. Requêtes indépendantes de la base de données, 3. Sécurité des types), tandis que SQL exploite directement la base de données (1. Normes indépendantes de la base de données, 2. Exécutable complexe requêtes et manipulation de données).

    Utilisation de l'opération de division dans Oracle SQL Utilisation de l'opération de division dans Oracle SQL Mar 10, 2024 pm 03:06 PM

    "Utilisation de l'opération de division dans OracleSQL" Dans OracleSQL, l'opération de division est l'une des opérations mathématiques courantes. Lors de l'interrogation et du traitement des données, les opérations de division peuvent nous aider à calculer le rapport entre les champs ou à dériver la relation logique entre des valeurs spécifiques. Cet article présentera l'utilisation de l'opération de division dans OracleSQL et fournira des exemples de code spécifiques. 1. Deux méthodes d'opérations de division dans OracleSQL Dans OracleSQL, les opérations de division peuvent être effectuées de deux manières différentes.

    Comparaison et différences de syntaxe SQL entre Oracle et DB2 Comparaison et différences de syntaxe SQL entre Oracle et DB2 Mar 11, 2024 pm 12:09 PM

    Oracle et DB2 sont deux systèmes de gestion de bases de données relationnelles couramment utilisés, chacun possédant sa propre syntaxe et ses propres caractéristiques SQL. Cet article comparera et différera la syntaxe SQL d'Oracle et de DB2, et fournira des exemples de code spécifiques. Connexion à la base de données Dans Oracle, utilisez l'instruction suivante pour vous connecter à la base de données : CONNECTusername/password@database Dans DB2, l'instruction pour vous connecter à la base de données est la suivante : CONNECTTOdataba.

    Explication détaillée de la fonction Définir la balise dans les balises SQL dynamiques MyBatis Explication détaillée de la fonction Définir la balise dans les balises SQL dynamiques MyBatis Feb 26, 2024 pm 07:48 PM

    Interprétation des balises SQL dynamiques MyBatis : explication détaillée de l'utilisation des balises Set MyBatis est un excellent cadre de couche de persistance. Il fournit une multitude de balises SQL dynamiques et peut construire de manière flexible des instructions d'opération de base de données. Parmi elles, la balise Set est utilisée pour générer la clause SET dans l'instruction UPDATE, qui est très couramment utilisée dans les opérations de mise à jour. Cet article expliquera en détail l'utilisation de la balise Set dans MyBatis et démontrera ses fonctionnalités à travers des exemples de code spécifiques. Qu'est-ce que Set tag Set tag est utilisé dans MyBati

    Que signifie l'attribut d'identité dans SQL ? Que signifie l'attribut d'identité dans SQL ? Feb 19, 2024 am 11:24 AM

    Qu'est-ce que l'identité en SQL ? Des exemples de code spécifiques sont nécessaires. En SQL, l'identité est un type de données spécial utilisé pour générer des nombres à incrémentation automatique. Il est souvent utilisé pour identifier de manière unique chaque ligne de données dans une table. La colonne Identité est souvent utilisée conjointement avec la colonne clé primaire pour garantir que chaque enregistrement possède un identifiant unique. Cet article détaillera comment utiliser Identity et quelques exemples de code pratiques. La manière de base d'utiliser Identity consiste à utiliser Identit lors de la création d'une table.

    Comment implémenter Springboot+Mybatis-plus sans utiliser d'instructions SQL pour ajouter plusieurs tables Comment implémenter Springboot+Mybatis-plus sans utiliser d'instructions SQL pour ajouter plusieurs tables Jun 02, 2023 am 11:07 AM

    Lorsque Springboot+Mybatis-plus n'utilise pas d'instructions SQL pour effectuer des opérations d'ajout de plusieurs tables, les problèmes que j'ai rencontrés sont décomposés en simulant la réflexion dans l'environnement de test : Créez un objet BrandDTO avec des paramètres pour simuler le passage des paramètres en arrière-plan. qu'il est extrêmement difficile d'effectuer des opérations multi-tables dans Mybatis-plus. Si vous n'utilisez pas d'outils tels que Mybatis-plus-join, vous pouvez uniquement configurer le fichier Mapper.xml correspondant et configurer le ResultMap malodorant et long, puis. écrivez l'instruction SQL correspondante Bien que cette méthode semble lourde, elle est très flexible et nous permet de

    Comment résoudre l'erreur 5120 dans SQL Comment résoudre l'erreur 5120 dans SQL Mar 06, 2024 pm 04:33 PM

    Solution : 1. Vérifiez si l'utilisateur connecté dispose des autorisations suffisantes pour accéder ou utiliser la base de données, et assurez-vous que l'utilisateur dispose des autorisations appropriées ; 2. Vérifiez si le compte du service SQL Server est autorisé à accéder au fichier spécifié ou ; dossier et assurez-vous que le compte dispose des autorisations suffisantes pour lire et écrire le fichier ou le dossier ; 3. Vérifiez si le fichier de base de données spécifié a été ouvert ou verrouillé par d'autres processus, essayez de fermer ou de libérer le fichier et réexécutez la requête ; . Essayez en tant qu'administrateur, exécutez Management Studio en tant que etc.

    Comment utiliser les instructions SQL pour l'agrégation de données et les statistiques dans MySQL ? Comment utiliser les instructions SQL pour l'agrégation de données et les statistiques dans MySQL ? Dec 17, 2023 am 08:41 AM

    Comment utiliser les instructions SQL pour l'agrégation de données et les statistiques dans MySQL ? L'agrégation des données et les statistiques sont des étapes très importantes lors de l'analyse des données et des statistiques. En tant que puissant système de gestion de bases de données relationnelles, MySQL fournit une multitude de fonctions d'agrégation et de statistiques, qui peuvent facilement effectuer des opérations d'agrégation de données et de statistiques. Cet article présentera la méthode d'utilisation des instructions SQL pour effectuer l'agrégation de données et les statistiques dans MySQL, et fournira des exemples de code spécifiques. 1. Utilisez la fonction COUNT pour compter. La fonction COUNT est la plus couramment utilisée.

    See all articles