首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Python/Mysql:拒绝转义字符串!

Python/Mysql:拒绝转义字符串!
EN

Stack Overflow用户
提问于 2011-06-08 01:29:36
回答 1查看 356关注 0票数 0

我有一个很长的查询需要执行,并且我正在使用准备好的语句将值插入到查询中。据我所知,它应该是工作的,但它不工作!

代码如下:

代码语言:javascript
运行
复制
    cursor = connection.cursor()
    rows = cursor.execute(r"""SELECT... %s.. %s.. %s...""",(val1,val2,val3,))
    rows = cursor.fetchall()
    rows = text_position(rows)

如果我插入一个简单的-引号,它会断开,如果我插入任何非英语字符,情况也是一样。当我将语句放在双引号中时,它可以使用双引号。有什么建议吗?

EN

回答 1

Stack Overflow用户

发布于 2011-06-08 01:42:47

这是一种调试SQL的通用技术(特别是从另一种语言生成时,如Python):

停止mysql服务器(假设您在运行mysqld时没有记录日志):

代码语言:javascript
运行
复制
sudo invoke-rc.d mysql stop

在打开日志记录的情况下运行mysqld

代码语言:javascript
运行
复制
sudo mysqld --log=/tmp/myquery.log

运行您的脚本。

在/tmp/myquery.log中查找MySQLdb发送给mysqld的SQL命令。

这可能会为您提供足够的线索来解决问题,否则,请使用Python发布完整的SQL命令

代码语言:javascript
运行
复制
cursor.execute(r"""SELECT... %s.. %s.. %s...""",(val1,val2,val3,))

以及mysqld在/tmp/myquery.log中看到的相应SQL。

调试完成后,您可以关闭日志记录mysqld,然后使用以下命令重新启动:

代码语言:javascript
运行
复制
sudo invoke-rc.d mysql restart
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6269234

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档