>데이터 베이스 >MySQL 튜토리얼 >PyODBC SELECT 문에서 매개변수 변수를 어떻게 안전하게 사용할 수 있나요?

PyODBC SELECT 문에서 매개변수 변수를 어떻게 안전하게 사용할 수 있나요?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-02 19:15:39586검색

How Can I Safely Use Parameter Variables in a PyODBC SELECT Statement?

PyODBC: 매개변수 변수를 사용하여 Select 문 수행

이 시나리오에서는 처리량 테이블에서 행을 검색합니다. data['DeviceName']에 저장된 특정 DeviceName. 그러나 이전에 매개변수 변수를 사용하여 SELECT 문을 실행하려는 시도는 실패했습니다.

해결책은 SQL 문에 매개변수화를 사용하는 것입니다. "?"를 사용하여 자리 표시자와 DeviceName을 인수로 전달하면 SQL 주입 및 기타 보안 취약성으로부터 시스템을 보호할 수 있습니다.

수정된 접근 방식은 다음과 같습니다.

cursor.execute("SELECT * FROM Throughput WHERE DeviceName = ?", data['DeviceName'])

매개변수화는 여러 가지 이점을 제공합니다.

  • SQL 주입 방지: 악의적인 입력으로 인해 데이터베이스가 변경되는 것을 방지합니다. 동작.
  • 이스케이프 문자 사용 제거: 매개변수 값의 자동 처리를 통해 작은따옴표로 개별 값을 이스케이프 처리할 필요가 없습니다.
  • 향상된 성능: SQL 준비문은 한 번 생성되어 재사용되므로 쿼리 속도가 빨라집니다.

수정된 쿼리 스니펫 외에도 다음은 참조용으로 작동하는 코드 예제의 일부입니다.

query = "SELECT * FROM Throughput WHERE DeviceName = '%s'" % data['DeviceName']
try:
    for row in cursor.execute(query):
        ...

매개변수화된 또는 보안 강화를 위한 동적 SQL.

위 내용은 PyODBC SELECT 문에서 매개변수 변수를 어떻게 안전하게 사용할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.