집 >데이터 베이스 >MySQL 튜토리얼 >Python을 사용하여 MySQL 쿼리에서 백분율 기호(%)를 이스케이프하는 방법은 무엇입니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!