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

Barbara Streisand
풀어 주다: 2024-11-01 17:32:02
원래의
797명이 탐색했습니다.

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!