Eine detaillierte Erklärung der Zeilenwerte in SQL
In der WHERE-Klausel von SQL werden häufig Zeilenwerte verglichen, z. B. (col1, col2) < (val1, val2)
. Dieser Artikel befasst sich mit der Syntax und Funktionalität dieses Zeilenwertvergleichs sowie seiner Anwendung in Datenbankabfragen.
Kernkonzepte
(col1, col2)
, um einen Zeilenwertvergleich durchzuführen. Diese Syntax wird häufig bei der „Keyset-Paginierung“ verwendet, um Datensätze vor oder nach einer bestimmten Zeile abzurufen.
Syntax und Funktionalität
Der Ausdruck (col1, col2) < (val1, val2)
bedeutet: wenn col1 < val1
, ist der Ausdruck wahr; wenn col1 = val1
und col2 < val2
, ist der Ausdruck auch wahr; andernfalls ist er falsch.
Dies unterscheidet sich vom ausführlicheren äquivalenten Ausdruck:
<code class="language-sql">(col1 < val1) OR (col1 = val1 AND col2 < val2)</code>
PostgreSQL kann mehrspaltige Indizes auf (col1, col2)
oder (col1 DESC, col2 DESC)
nutzen, um solche Abfragen zu optimieren. Beachten Sie, dass der Zeilenwertvergleich nicht dasselbe ist wie:
<code class="language-sql">col1 < val1 AND col2 < val2</code>
Der Unterschied ist offensichtlich, wenn man Zeilenwerte wie (1,1)
berücksichtigt.
Weitere Ressourcen
Weitere Informationen finden Sie in Markus Winands Präsentation „The Correct Way to Paginate in PostgreSQL“:
Die richtige Art der Paginierung in PostgreSQL
Der Zeilenwertvergleich wird auf Seite 20 erläutert und die unterstützende Matrix wird auf Seite 45 bereitgestellt.
Das obige ist der detaillierte Inhalt vonWie geht SQL mit Zeilenwertvergleichen in WHERE-Klauseln um?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!