python3 mysql escape,如何在Python3中将输入转义到MySQL数据库?

How can I escape the input to a MySQL db in Python3?

I'm using PyMySQL and works fine, but when I try to do something like:

cursor.execute("SELECT * FROM `Codes` WHERE `ShortCode` = '{}'".format(request[1]))

it won't work if the string has ' or ". I also tried:

cursor.execute("SELECT * FROM `Codes` WHERE `ShortCode` = %s",request[1])

The problem with this is that the library (PyMySQL) uses the formatting syntax for Python2.x, %, that doesn't work anymore.

I also found this possible solution

conn.escape_string()

in here, but I don't know where to add this code.

This is all I got:

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()

Edit: I solved it! In PyMySQL the right way is like this:

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()

Where the text = conn.escape(request[1]) line is what escapes the code. Found it inside PyMySQL code. There, request[1] is the input.

解决方案

Solved. In PyMySQL the right way is like this:

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()

Where the text = conn.escape(request[1]) line is what escapes the code. Found it inside PyMySQL code. There, request[1] is the input.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值