Maison > base de données > tutoriel mysql > Comment PostgreSQL trie-t-il les lignes dans les requêtes sélectionnées sans clause ORDER BY explicite ?

Comment PostgreSQL trie-t-il les lignes dans les requêtes sélectionnées sans clause ORDER BY explicite ?

Patricia Arquette
Libérer: 2024-10-30 04:24:28
original
876 Les gens l'ont consulté

How Does PostgreSQL Order Rows in Select Queries Without an Explicit ORDER BY Clause?

Dévoilement de l'ordre par défaut insaisissable dans les requêtes de sélection Postgres

Dans le domaine des requêtes de bases de données, PostgreSQL offre la fonctionnalité robuste de renvoi de données à partir de tables . Cependant, la manière dont ces données sont ordonnées, en particulier lors de la mise à jour des lignes, peut parfois prêter à confusion. Examinons plus en détail le comportement de classement par défaut employé par PostgreSQL dans les requêtes de sélection.

Considérons une table nommée check_user avec les données suivantes :

 id | name
----+------
  1 | x
  2 | y
  3 | z
  4 | a
  5 | c1\
  6 | c2
  7 | c3
Copier après la connexion

Lors de l'exécution d'une requête de sélection sans spécifier d'ordre explicite , PostgreSQL renvoie les lignes dans un ordre apparemment aléatoire :

<code class="postgres">postgres=# select * from check_user;
 id | name
----+------
  1 | x
  2 | y
  3 | z
  4 | a
  5 | c1\
  6 | c2
  7 | c3</code>
Copier après la connexion

Cependant, après avoir mis à jour une ligne (par exemple, en changeant 'c1' en 'c1') :

<code class="postgres">postgres=# update check_user set name = 'c1' where name = 'c1\';
UPDATE 1</code>
Copier après la connexion

Réexécuter le La requête select produit un résultat modifié :

<code class="postgres">postgres=# select * from check_user;
 id | name
----+------
  1 | x
  2 | y
  3 | z
  4 | a
  6 | c2
  7 | c3
  5 | c1</code>
Copier après la connexion

Les lignes sont désormais ordonnées différemment, ce qui soulève la question de savoir quel ordre par défaut PostgreSQL utilise. Essentiellement, PostgreSQL recourt à un classement implicite sans aucune spécification explicite de la part de l'utilisateur. Cependant, cet ordre par défaut n'est pas prévisible et peut varier en fonction de facteurs tels que les méthodes de récupération de données (par exemple, analyses séquentielles ou utilisation d'index), le stockage des pages mémoire et même les variables environnementales.

Il est crucial de souligner que cet ordre par défaut ne doit pas être invoqué pour obtenir des résultats cohérents. Il s’agit d’un comportement indéfini et le fait de s’y fier peut conduire à des résultats inattendus. Pour garantir un classement prévisible, il est recommandé de spécifier explicitement les critères de classement souhaités dans les requêtes sélectionnées à l'aide de la clause ORDER BY :

<code class="postgres">postgres=# select * from check_user ORDER BY name;
 id | name
----+------
  1 | a
  2 | c1
  3 | c2
  4 | c3
  5 | x
  6 | y
  7 | z</code>
Copier après la connexion

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!

source:php.cn
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal