파이썬 목록이 있습니다.
l = [1,5,8]
목록의 모든 요소에 대한 데이터를 가져 오는 SQL 쿼리를 작성하고 싶습니다.
select name from students where id = |IN THE LIST l|
어떻게해야합니까?
답변
지금까지 답변은 값을 일반 SQL 문자열로 템플릿 화했습니다. 정수의 경우 절대적으로 괜찮지 만 문자열에 대해 수행하려면 이스케이프 문제가 발생합니다.
다음은 두 가지 모두에서 작동하는 매개 변수화 된 쿼리를 사용하는 변형입니다.
placeholder= '?' # For SQLite. See DBAPI paramstyle.
placeholders= ', '.join(placeholder for unused in l)
query= 'SELECT name FROM students WHERE id IN (%s)' % placeholders
cursor.execute(query, l)
답변
가장 쉬운 방법은 목록을 tuple
처음 으로 바꾸는 것입니다.
t = tuple(l)
query = "select name from studens where id IN {}".format(t)
답변
그것을 복잡하게하지 마십시오. 이에 대한 해결책은 간단합니다.
l = [1,5,8]
l = tuple(l)
params = {'l': l}
cursor.execute('SELECT * FROM table where id in %(l)s',params)
이것이 도움이 되었기를 바랍니다 !!!
답변
원하는 SQL은
select name from studens where id in (1, 5, 8)
파이썬에서 이것을 구성하려면 다음을 사용할 수 있습니다.
l = [1, 5, 8]
sql_query = 'select name from studens where id in (' + ','.join(map(str, l)) + ')'
지도 기능은 사용 쉼표로 서로 접착 될 수있는 문자열리스트로 변환리스트 것이다 str.join의 방법.
또는 :
l = [1, 5, 8]
sql_query = 'select name from studens where id in (' + ','.join((str(n) for n in l)) + ')'
map 함수보다 생성기 표현식 을 선호하는 경우 .
업데이트 : S. Lott 는 주석에서 Python SQLite 바인딩이 시퀀스를 지원하지 않는다고 언급했습니다. 이 경우에는
select name from studens where id = 1 or id = 5 or id = 8
에 의해 생성 된
sql_query = 'select name from studens where ' + ' or '.join(('id = ' + str(n) for n in l))
답변
string.join 쉼표로 구분하여리스트의 값을 사용하여 포맷 연산자 쿼리 스트링을 형성한다.
myquery = "select name from studens where id in (%s)" % ",".join(map(str,mylist))
(감사합니다, 블레어 콘래드 )
답변
나는 bobince의 대답을 좋아합니다.
placeholder= '?' # For SQLite. See DBAPI paramstyle.
placeholders= ', '.join(placeholder for unused in l)
query= 'SELECT name FROM students WHERE id IN (%s)' % placeholders
cursor.execute(query, l)
그러나 나는 이것을 발견했습니다.
placeholders= ', '.join(placeholder for unused in l)
다음으로 대체 가능 :
placeholders= ', '.join(placeholder*len(l))
덜 영리하고 덜 일반적이라면 이것이 더 직접적이라고 생각합니다. 여기 l
에 길이가 필요합니다 (즉, __len__
메서드 를 정의하는 객체를 참조 ). 이는 문제가되지 않습니다. 그러나 자리 표시자는 단일 문자 여야합니다. 다중 문자 자리 표시자를 지원하려면 다음을 사용하십시오.
placeholders= ', '.join([placeholder]*len(l))
답변
(1,)이 유효한 SQL이 아니기 때문에 단일 요소 튜플로 중단 되었기 때문에 @umounted 답변에 대한 솔루션입니다. :
>>> random_ids = [1234,123,54,56,57,58,78,91]
>>> cursor.execute("create table test (id)")
>>> for item in random_ids:
cursor.execute("insert into test values (%d)" % item)
>>> sublist = [56,57,58]
>>> cursor.execute("select id from test where id in %s" % str(tuple(sublist)).replace(',)',')'))
>>> a = cursor.fetchall()
>>> a
[(56,), (57,), (58,)]
SQL 문자열에 대한 다른 솔루션 :
cursor.execute("select id from test where id in (%s)" % ('"'+'", "'.join(l)+'"'))