Heim >Datenbank >MySQL-Tutorial >Warum erfordert MySQL das Backslash-Escape für LIKE, aber nicht für =?

Warum erfordert MySQL das Backslash-Escape für LIKE, aber nicht für =?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2025-01-06 21:04:41903Durchsuche

Why Does MySQL Require Backslash Escaping for LIKE but Not for =?

Backslash in MySQL entkommen: Die Unterschiede zwischen Gleichheits- (=) und LIKE-Operatoren aufdecken

In MySQL das Backslash ()-Zeichen spielt eine entscheidende Rolle bei der String-Manipulation. Bei Verwendung des Gleichheitsoperators (=) ist das Escapezeichen des Backslashs nicht erforderlich, im Gegensatz zum LIKE-Operator, bei dem ein zusätzlicher Backslash erforderlich ist.

Betrachten Sie die folgende Abfrage:

(SELECT * FROM `titles` WHERE title = 'test\')
UNION ALL
(SELECT * FROM `titles` WHERE title LIKE 'test\\')

Die Ausgabe von Diese Abfrage zeigt, dass beide Bedingungen übereinstimmen und dieselbe Zeile zurückgeben. Dies mag kontraintuitiv erscheinen, da die zweite Bedingung einen zusätzlichen Backslash enthält.

Warum ist Escapen für (=) nicht erforderlich, aber für LIKE erforderlich?

Das Die Antwort liegt im einzigartigen Verhalten des LIKE-Operators. Im Gegensatz zum Gleichheitsoperator (=) verwendet LIKE Backslashes als Escape-Zeichen. Das bedeutet, dass jeder Backslash in einem LIKE-Muster verdoppelt werden muss, um wortwörtlich gefunden zu werden.

MySQL führt diese Verdoppelung in zwei Schritten durch:

  • Einmal durch den Parser, der einen Backslash entfernt.
  • Erneut, wenn der Musterabgleich durchgeführt wurde, bleibt ein einzelner Backslash übrig, der mit dem abgeglichen werden muss string.

Daher maskiert MySQL in der ersten Bedingung (title = 'test') automatisch den Backslash, was zu einer Übereinstimmung führt. In der zweiten Bedingung (Titel LIKE 'test\') ist der zusätzliche Backslash jedoch erforderlich, da er die zwei Runden des Backslash-Strippings kompensiert.

Benutzerdefiniertes Escape-Zeichen für LIKE-Muster

In bestimmten Szenarien kann es wünschenswert sein, ein anderes Escape-Zeichen für LIKE-Muster zu verwenden. Dies kann mit dem Schlüsselwort ESCAPE erreicht werden, wie unten gezeigt:

SELECT * FROM `titles` WHERE title LIKE 'test\' ESCAPE '|'

Durch Angabe des Schlüsselworts ESCAPE wird das '|' Das Zeichen wird zum Escape-Zeichen anstelle des Standardzeichens ''. Dadurch können Sie das Backslash-Zeichen buchstäblich in LIKE-Mustern verwenden, ohne es verdoppeln zu müssen.

Das obige ist der detaillierte Inhalt vonWarum erfordert MySQL das Backslash-Escape für LIKE, aber nicht für =?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn