Heim > Datenbank > MySQL-Tutorial > Wie kann ich Prozentzeichen (%) in MySQL-Abfragen mit Python maskieren?

Wie kann ich Prozentzeichen (%) in MySQL-Abfragen mit Python maskieren?

DDD
Freigeben: 2024-11-18 01:08:02
Original
280 Leute haben es durchsucht

How to Escape Percent Signs (%) in MySQL Queries Using Python?

So maskieren Sie %-Zeichen in MySQL-Abfragen mit Python

Beim Erstellen von MySQL-Abfragen in Python ist es notwendig, bestimmte Zeichen zu maskieren, darunter das Prozentzeichen (%). Andernfalls kann es zu Fehlern kommen.

Bedenken Sie die folgende Abfrage:

query = """SELECT DATE_FORMAT(date_time,'%Y-%m') AS dd
FROM some_table
WHERE some_col = %s
AND other_col = %s;"""

cur.execute(query, (pram1, pram2))
Nach dem Login kopieren

Das Ausführen dieser Abfrage führt zur Ausnahme „ValueError: nicht unterstütztes Formatzeichen ‚Y‘“. Dies liegt daran, dass MySQL das %-Zeichen als Formatbezeichner innerhalb der DATE_FORMAT-Funktion interpretiert, anstatt es als Literalzeichen zu behandeln.

Um dieses Problem zu beheben, wird empfohlen, Literal-Escapezeichen zu verwenden, wie vom MySQL Connector/ vorgeschlagen. Python-Dokumentation:

literal% = '%%'  # Define a literal percent string
query = """SELECT DATE_FORMAT(date_time,'{}') AS dd
FROM some_table
WHERE some_col = %s
AND other_col = %s;""".format(literal%)

cur.execute(query, (pram1, pram2))
Nach dem Login kopieren

Indem Sie das Prozentzeichen mit einem anderen Prozentzeichen maskieren, wird die Abfrage korrekt ausgeführt, ohne dass sie von der Interpretation des Formatbezeichners beeinflusst wird. Dieser Ansatz stellt sicher, dass das Prozentzeichen innerhalb der Abfrage als Literalzeichen behandelt wird.

Das obige ist der detaillierte Inhalt vonWie kann ich Prozentzeichen (%) in MySQL-Abfragen mit Python maskieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage