Maison >base de données >tutoriel mysql >Comment exécuter des requêtes \'SELECT ... WHERE ... IN ...\' avec MySQLdb en Python ?
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!