亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

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 關注
  • 669 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號