Maison >base de données >tutoriel mysql >Comment exécuter des requêtes \'SELECT ... WHERE ... IN ...\' avec MySQLdb en Python ?

Comment exécuter des requêtes \'SELECT ... WHERE ... IN ...\' avec MySQLdb en Python ?

DDD
DDDoriginal
2024-11-02 17:19:29680parcourir

How to Execute

Exécuter "SELECT ... WHERE ... IN ..." À l'aide de MySQLdb

En Python, exécuter des requêtes SQL impliquant le " IN" utilisant MySQLdb peut rencontrer des défis. Considérez le scénario suivant :

Problème :

Tentative d'exécution d'une requête comme celle-ci :

<code class="sql">SELECT fooid FROM foo WHERE bar IN ('A','C');</code>

à partir de Python à l'aide du code suivant :

<code class="python">import MySQLdb
import config
connection=MySQLdb.connect(
    host=config.HOST,user=config.USER,passwd=config.PASS,db='test')
cursor=connection.cursor()

sql='SELECT fooid FROM foo WHERE bar IN %s'
args=[['A','C']]
cursor.execute(sql,args)
data=cursor.fetchall()
print(data)
# ()</code>

aboutit à un ensemble de données vide, malgré l'attente de deux lignes.

Cause :

MySQLdb ajoute automatiquement des guillemets simples autour des éléments dans les arguments de la liste d'entrée, ce qui entraîne l'exécution de la requête comme :

<code class="sql">SELECT fooid FROM foo WHERE bar IN ("'A'", "'C'")</code>

Cette requête diffère de la requête originale prévue, qui utilisait une liste entre guillemets simples.

Solution :

Pour surmonter ce problème, vous devez construire manuellement les paramètres de requête. Voici une version modifiée du code Python qui résout le problème :

<code class="python">import MySQLdb
import config
connection=MySQLdb.connect(
    host=config.HOST,user=config.USER,passwd=config.PASS,db='test')
cursor=connection.cursor()

args=['A', 'C']
sql='SELECT fooid FROM foo WHERE bar IN (%s)' 
in_p=', '.join(map(lambda x: '%s', args))
sql = sql % in_p
cursor.execute(sql, args)
data=cursor.fetchall()
print(data)
# (('1',), ('3',))</code>

En construisant la chaîne in_p à l'aide de map() et en la joignant par des virgules, vous créez efficacement une série d'espaces réservés pour les éléments dans args. L'utilisation de l'opérateur % garantit que les espaces réservés sont correctement remplacés par les valeurs réelles lorsque la requête est exécutée.

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn