Python 목록을 SQL 쿼리에 매개변수로 통합
값(예: [1, 5, 8]), 이러한 목록 요소를 기반으로 데이터베이스 테이블에서 데이터를 검색하려고 합니다. 특히 다음과 같은 SQL 쿼리를 실행하는 것을 목표로 합니다.
select name from students where id = |IN THE LIST l|
이를 달성하려면 SQL 문자열에 값을 직접 포함하는 것보다 더 다양하고 강력한 매개변수화된 쿼리 접근 방식을 사용하는 것이 좋습니다. 이 기술은 숫자 값과 문자열 값을 모두 효과적으로 처리하여 잠재적인 이스케이프 문제를 제거합니다.
다음 Python 코드 조각은 이 접근 방식을 보여줍니다.
placeholder= '?' # For SQLite. Adjust based on database parameter style. placeholders= ', '.join(placeholder for unused in l) query= 'SELECT name FROM students WHERE id IN (%s)' % placeholders cursor.execute(query, l)
자리 표시자(예: '?' )을 SQL 쿼리에 포함하고 이어서 목록(l)을 매개변수로 전달하면 데이터베이스에서 값이 올바르게 처리되는지 확인할 수 있습니다. 이 접근 방식은 데이터 무결성을 보장하고 제어되지 않은 문자열 연결로 인해 발생할 수 있는 잠재적인 SQL 주입 취약점을 방지합니다.
위 내용은 SQL `IN` 절에서 Python 목록을 매개변수로 어떻게 사용할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!