[python] 매개 변수로 SQL 쿼리의 파이썬 목록

파이썬 목록이 있습니다.

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)+'"'))