Kombination von LIKE und IN für flexiblen Mustervergleich in SQL Server
SQL Server-Abfragen können die Leistung von LIKE
und IN
für anspruchsvolle Mustervergleiche und Mengenvergleiche nutzen. Ihre direkte Kombination ist jedoch syntaktisch nicht gültig. Die Lösung liegt im strategischen Einsatz des OR
-Operators.
Angenommen, Sie möchten Zeilen finden, in denen eine Spalte mit mehreren Mustern übereinstimmt. Anstatt eine direkte Kombination von LIKE
und IN
zu versuchen, verwenden Sie mehrere LIKE
-Bedingungen, die durch OR
:
<code class="language-sql">SELECT * FROM your_table WHERE column LIKE 'Text%' OR column LIKE 'Hello%' OR column LIKE 'That%';</code>
Diese Abfrage sucht effektiv nach Zeilen, in denen column
mit „Text“, „Hallo“ oder „Das“ beginnt. Es werden Zeilen zurückgegeben, die Folgendes enthalten:
Dieser Ansatz spiegelt die Funktionalität von IN
wider (das Gleichheitsprüfungen durchführt), passt sie jedoch für den Mustervergleich mit LIKE
an. Beachten Sie, dass ein direktes IN
mit Platzhaltermustern (IN ('Text%', 'Hello%', 'That%')
) eine falsche SQL-Syntax darstellt.
Zur Verbesserung der Effizienz sollten Sie mehrere LIKE
-Bedingungen in einer einzigen LIKE
-Anweisung zusammenfassen, indem Sie den |
(OR)-Operator innerhalb des Musters verwenden:
<code class="language-sql">SELECT * FROM your_table WHERE column LIKE '%Text%|%Hello%|%That%';</code>
Diese optimierte Abfrage erzielt das gleiche Ergebnis mit einem präziseren und möglicherweise schnelleren Ausführungsplan. Denken Sie daran, bei Bedarf alle Sonderzeichen in Ihren Suchmustern zu maskieren.
Das obige ist der detaillierte Inhalt vonWie kann ich die LIKE- und IN-Funktionalität in SQL Server für den Mustervergleich kombinieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!