>데이터 베이스 >MySQL 튜토리얼 >Python을 사용하여 MySQL 쿼리에서 백분율 기호(%)를 이스케이프하는 방법은 무엇입니까?

Python을 사용하여 MySQL 쿼리에서 백분율 기호(%)를 이스케이프하는 방법은 무엇입니까?

DDD
DDD원래의
2024-11-18 01:08:02242검색

How to Escape Percent Signs (%) in MySQL Queries Using Python?

Python을 사용하여 MySQL 쿼리에서 % 문자를 이스케이프하는 방법

Python에서 MySQL 쿼리를 구성할 때 다음을 포함한 특정 문자를 이스케이프해야 합니다. 퍼센트 기호(%). 그렇지 않으면 오류가 발생할 수 있습니다.

다음 쿼리를 고려하십시오.

query = """SELECT DATE_FORMAT(date_time,'%Y-%m') AS dd
FROM some_table
WHERE some_col = %s
AND other_col = %s;"""

cur.execute(query, (pram1, pram2))

이 쿼리를 실행하면 "ValueError: 지원되지 않는 형식 문자 'Y'" 예외가 발생합니다. 이는 MySQL이 % 문자를 리터럴 문자로 처리하는 대신 DATE_FORMAT 함수 내의 형식 지정자로 해석하기 때문에 발생합니다.

이 문제를 해결하려면 MySQL 커넥터/에서 제안한 대로 리터럴 이스케이프를 사용하는 것이 좋습니다. Python 문서:

literal% = '%%'  # Define a literal percent string
query = """SELECT DATE_FORMAT(date_time,'{}') AS dd
FROM some_table
WHERE some_col = %s
AND other_col = %s;""".format(literal%)

cur.execute(query, (pram1, pram2))

백분율 문자를 다른 백분율 기호로 이스케이프하면 쿼리는 다음의 영향을 받지 않고 올바르게 실행됩니다. 형식 지정자 해석. 이 접근 방식을 사용하면 백분율 기호가 쿼리 내에서 리터럴 문자로 처리됩니다.

위 내용은 Python을 사용하여 MySQL 쿼리에서 백분율 기호(%)를 이스케이프하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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