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

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

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

慕田峪7331174 2019-02-24 21:56:33
mysql的数据表是这样的: +----+------+------+ | id | name | age | +----+------+------+ | 1 | cxx | 25 | +----+------+------+ 我的python代码: cursor = conn.cursor() add_user = """insert into person(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 * from person where name = (%s)""" select_data = (newName) cursor.execute(select_user,select_data) conn.commit() values = cursor.fetchall() values 上半部分的插入语句是可以正常执行的,但是下半部分的搜索语句总是报错, ProgrammingError: 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '%s)' at line 1 应该是字符串处理问题。。select_data没有替换掉select_user中的%s,但是上面的为什么就可以。。求高手解答
查看完整描述

2 回答

?
繁花不似锦

TA贡献1851条经验 获得超4个赞

最终解决方案:
select_user = r'select * from person where name = %s'
select_data = (newName, )

查看完整回答
反对 回复 2019-03-01
?
吃鸡游戏

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

"""select * from person where name = (%s)""" 

估计是这里错了,为何要加括号呢?换成下面的试试

"""select * from person where name = %s """ 
查看完整回答
反对 回复 2019-03-01
  • 2 回答
  • 0 关注
  • 658 浏览
慕课专栏
更多

添加回答

举报

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