>데이터 베이스 >MySQL 튜토리얼 >MySQLdb에서 \'SELECT ... WHERE ... IN ...\' 쿼리가 실패하는 이유는 무엇입니까?

MySQLdb에서 \'SELECT ... WHERE ... IN ...\' 쿼리가 실패하는 이유는 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-01 17:32:02944검색

Why is

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

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.