집 >데이터 베이스 >MySQL 튜토리얼 >MySQLdb에서 \'SELECT ... WHERE ... IN ...\' 쿼리가 실패하는 이유는 무엇입니까?
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" 절의 값을 연결해야 합니다.
<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>
또는 Python 2의 경우 다음 코드를 사용할 수 있습니다.
<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>
이것은 코드는 배열의 값을 반복하고 쉼표로 결합하여 올바른 수의 자리 표시자('%s')가 포함된 SQL 문자열을 동적으로 생성합니다. 수동으로 생성된 이 쿼리를 실행하면 "bar" 열이 ('A','C')에 있는 fooid를 선택하여 예상한 결과를 얻을 수 있습니다
위 내용은 MySQLdb에서 \'SELECT ... WHERE ... IN ...\' 쿼리가 실패하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!