MySQL参数化查询
我很难使用MySQLdb模块将信息插入到我的数据库中。我需要在表中插入6个变量。
cursor.execute (""" INSERT INTO Songs (SongName, SongArtist, SongAlbum, SongGenre, SongLength, SongLocation)
VALUES
(var1, var2, var3, var4, var5, var6)
""")
有人可以帮我这里的语法吗?
回答:
提防对SQL查询使用字符串插值,因为它不能正确地转义输入参数,并使您的应用程序容易受到SQL注入漏洞的影响。
。
不正确(存在安全问题)
c.execute("SELECT * FROM foo WHERE bar = %s AND baz = %s" % (param1, param2))
正确(带有转义符)
c.execute("SELECT * FROM foo WHERE bar = %s AND baz = %s", (param1, param2))
这增加了混乱,即用于绑定SQL语句中的参数的修饰符在不同的DB
API实现之间有所不同,并且mysql客户端库使用printf
样式语法而不是更普遍接受的’?’。标记(例如,使用python-sqlite
)。
以上是 MySQL参数化查询 的全部内容, 来源链接: utcz.com/qa/435809.html