Python의 SQL 문에 변수 사용
Python에서 데이터베이스 작업을 수행할 때 변수를 SQL 문에 통합해야 하는 경우가 많습니다. 그러나 이러한 변수가 쿼리 텍스트에 직접 포함된 경우 Python은 이를 쿼리의 일부로 해석하므로 예기치 않은 결과가 발생할 수 있습니다.
이 문제를 방지하려면 변수를 SQL에 매개 변수로 전달해야 합니다. 성명. 이를 달성하기 위해 선호되는 방법은 쿼리에서 자리 표시자를 사용하고 값을 튜플로 전달하는 것입니다:
cursor.execute("INSERT INTO table VALUES (%s, %s, %s)", (var1 , var2, var3))
이 예에서는
데이터베이스 API는 값의 적절한 이스케이프 처리 및 인용을 처리하여 데이터베이스에 안전하게 삽입되도록 합니다.
유의하는 것이 중요합니다. (%)와 같은 문자열 형식 연산자를 사용하여 변수를 삽입하는 것은 적절한 이스케이프를 제공하지 않아 SQL 주입 공격과 같은 보안 취약점으로 이어질 수 있으므로 권장되지 않습니다.
위 내용은 Python SQL 문에서 변수를 안전하게 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!