如何在 Python3 中将输入转义到 MySQL 数据库?我正在使用 PyMySQL 并且工作正常,但是当我尝试执行以下操作时:
cursor.execute("SELECT * FROM `Codes` WHERE `ShortCode` = '{}'".format(request[1]))
'
如果字符串有or ,它将不起作用"
。我也试过:
cursor.execute("SELECT * FROM `Codes` WHERE `ShortCode` = %s",request[1])
问题在于库(PyMySQL)使用 Python2.x, 的格式化语法%
,这不再有效。我也找到了这个可能的解决方案
conn.escape_string()
在这里,但我不知道在哪里添加此代码。这就是我得到的全部:
import pymysql
import sys
conn = pymysql.connect( host = "localhost",
user = "test",
passwd = "",
db = "test")
cursor = conn.cursor()
cursor.execute("SELECT * FROM `Codes` WHERE `ShortCode` = {}".format(request[1]))
result = cursor.fetchall()
cursor.close()
conn.close()
编辑:我解决了!在 PyMySQL 中正确的方法是这样的:
import pymysql
import sys
conn = pymysql.connect(host="localhost",
user="test",
passwd="",
db="test")
cursor = conn.cursor()
text = conn.escape(request[1])
cursor.execute("SELECT * FROM `Codes` WHERE `ShortCode` = {}".format(text))
cursor.close()
conn.close()
该text = conn.escape(request[1])
行是转义代码的地方。在 PyMySQL 代码中找到它。在那里,request[1]
是输入。