<p><img src="https://img.php.cn/upload/article/000/000/000/173646916331017.jpg" alt="How Does SQL's `(col1, col2) < (val1, val2)` Row Value Comparison Work?
"></p>
<p><strong>Comparaison des valeurs de lignes SQL : compréhension de la <code>(col1, col2) < (val1, val2)</code> syntaxe</strong></p>
<p>La clause <code>WHERE</code> de SQL permet des conditions de sélection de données flexibles et diverses, notamment la comparaison de plusieurs colonnes dans une seule expression. Une syntaxe courante est <code>WHERE (col1, col2) < (val1, val2)</code>. </p>
<p>Ce type de condition est appelé « comparaison de valeurs de ligne » ou « comparaison ligne par ligne ». Il utilise le constructeur de ligne (noté ROW(col1, col2)) pour comparer la valeur d'une ligne entière avec la valeur d'une autre ligne. Les opérateurs <code><</code>, <code>></code>, <code><=</code>, <code>>=</code>, <code>=</code> et <code>!=</code> soutiennent tous cette comparaison. </strong></p>
<p>La fonctionnalité de comparaison des valeurs de ligne remonte à la norme SQL-92, et PostgreSQL est actuellement le seul système de gestion de base de données relationnelle (SGBDR) majeur à la prendre entièrement en charge, y compris l'optimisation des index. </p>
<p>Dans l'exemple fourni, la signification de <code>WHERE (col1, col2) < (val1, val2)</code> est : si <code>col1</code> est inférieur à <code>val1</code>, ou si <code>col1</code> est égal à <code>val1</code> et <code>col2</code> est inférieur à <code>val2</code>, alors la ligne satisfait à la condition. </p>
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false"><code class="language-sql">--示例
SELECT * FROM my_table WHERE (col1, col2) < (10, 20);</code></pre><div class="contentsignin">Copier après la connexion</div></div>
<p>Notez qu'il s'agit d'une syntaxe différente de <code>WHERE col1 < val1 AND col2 < val2</code>. Ce dernier exige que <code>col1</code> et <code>col2</code> soient plus petits que leurs valeurs correspondantes, tandis que les comparaisons de valeurs de ligne sont comparées ligne par ligne. </p>
<p>Pour effectuer efficacement des comparaisons de valeurs de lignes, PostgreSQL utilise des index multi-colonnes et l'ordre des index peut être <code>(col1, col2)</code> ou <code>(col1 DESC, col2 DESC)</code>. Les index avec des directions de tri mixtes (par exemple <code>(col1 ASC, col2 DESC)</code>) ne s'appliquent pas. </p>
<p>En comprenant le concept de comparaison des valeurs de ligne, les développeurs peuvent exploiter ses capacités pour effectuer efficacement des tâches de sélection de données, en particulier dans les scénarios de pagination de jeux de clés. </p>
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!