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
Libérer: 2024-11-02 17:19:29
original
690 Les gens l'ont consulté

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>
Copier après la connexion

à 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>
Copier après la connexion

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>
Copier après la connexion

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>
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal