为了账号安全,请及时绑定邮箱和手机立即绑定

python中使用mysql.connector连接mysql时,几乎一样的语句insert可以,但是select就报错,求助

python中使用mysql.connector连接mysql时,几乎一样的语句insert可以,但是select就报错,求助

守着一只汪 2019-04-16 17:05:23
mysql的数据表是这样的:+----+------+------+|id|name|age|+----+------+------+|1|cxx|25|+----+------+------+我的python代码:cursor=conn.cursor()add_user="""insertintoperson(name,age)VALUES(%s,%s)"""data_user=(newName,newAge)cursor.execute(add_user,data_user)conn.commit()cursor.close()cursor=conn.cursor()select_user="""select*frompersonwherename=(%s)"""select_data=(newName)cursor.execute(select_user,select_data)conn.commit()values=cursor.fetchall()values上半部分的插入语句是可以正常执行的,但是下半部分的搜索语句总是报错,ProgrammingError:1064(42000):YouhaveanerrorinyourSQLsyntax;checkthemanualthatcorrespondstoyourMySQLserverversionfortherightsyntaxtousenear'%s)'atline1应该是字符串处理问题。。select_data没有替换掉select_user中的%s,但是上面的为什么就可以。。求高手解答
查看完整描述

2 回答

?
慕神8447489

TA贡献1780条经验 获得超1个赞

最终解决方案:
select_user=r'select*frompersonwherename=%s'
select_data=(newName,)
                            
查看完整回答
反对 回复 2019-04-16
?
哔哔one

TA贡献1854条经验 获得超8个赞

"""select*frompersonwherename=(%s)"""
估计是这里错了,为何要加括号呢?换成下面的试试
"""select*frompersonwherename=%s"""
                            
查看完整回答
反对 回复 2019-04-16
  • 2 回答
  • 0 关注
  • 460 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号