MySQLdb を使用して "SELECT ... WHERE ... IN ..." を実行しています
からの SQL クエリの実行は成功しましたが、 MySQL コマンドラインでは、MySQLdb を使用して Python 内から「WHERE ... IN ...」構文を使用してクエリを実行すると問題が発生する可能性があります。問題を調査し、解決策を検討してみましょう。
あなたの場合、「IN」句で「bar」列をフィルタリングするクエリでは行を取得できませんが、「」をフィルタリングする同様のクエリでは行を取得できません。 "IN" を含む fooid" 列は成功します。この不一致は、MySQLdb がパラメータ化されたクエリを処理する方法に原因がある可能性があります。
値の配列を MySQLdb への引数として指定すると、それが一重引用符で囲まれた文字列のタプルに自動的に変換され、その結果、構文が正しくなくなります。 「IN」句。たとえば、コードは ['A','C'] を ("'A'","'C'") に変換します。 args=[['A','C']]
これを解決するには、SQL 文字列を手動で構築し、Python を使用して「IN」句の値を連結する必要があります。
Python 2 の場合は、次のコードを使用することもできます。<code class="python">args=['A', 'C'] sql='SELECT fooid FROM foo WHERE bar IN (%s)' in_p=', '.join(list(map(lambda x: '%s', args))) sql = sql % in_p cursor.execute(sql, args)</code>
<code class="python">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)</code>
以上がMySQLdb で「SELECT ... WHERE ... IN ...」クエリが失敗するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。