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

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

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

慕容森 2019-04-07 11:18:56
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 回答

?
吃鸡游戏

TA贡献1829条经验 获得超7个赞

最终解决方案:
select_user=r'select*frompersonwherename=%s'
select_data=(newName,)
                            
查看完整回答
反对 回复 2019-04-07
?
一只萌萌小番薯

TA贡献1795条经验 获得超7个赞

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

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信