Échapper % des requêtes MySQL en Python
L'utilisation du caractère % dans les requêtes MySQL peut conduire à des exceptions s'il n'est pas échappé correctement. Par exemple, la requête suivante :
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))
lèvera une exception "ValueError : caractère de format non pris en charge 'Y'" car mysqldb interprète le % comme un spécificateur de format.
Pour résoudre ce problème , l'échappement littéral est recommandé par la documentation mysqldb. Cela implique de doubler les % caractères dans la chaîne de requête :
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))
Cela empêchera mysqldb d'interpréter les % caractères comme spécificateurs de format, permettant ainsi à la requête de s'exécuter avec succès.
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!