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 중국어 웹사이트의 기타 관련 기사를 참조하세요!