使用Python的pymysql插入数据返回成功但数据库没有数据,ID却自增了

在使用Python的pymysql库插入数据时遇到问题,虽然返回1表示成功,但数据库中并未实际保存数据,同时ID自增。通过分析,发现是事务处理未提交导致。解决方案是在执行SQL后调用`commit()`方法来提交更改,避免使用`rollback()`回滚。修复后,数据能正常插入且ID自增连续。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

大家好,我是专职Android研发,有14年研发经验,其中Android研发经验已经有10年。
曾任职上市公司,有车机导航、机器人等行业及研发经验,热衷于技术和研发。
除Android专业外,也研究并使用Python、PHP、JavaScript、前端、中间件、数据库等技术。
目前开始通过博客对自己的知识和经验进行归纳和总结,由于工作较忙,不定期去更新博客。
希望本博客的内容能够真正帮助到一些同学。
个人博客:Dzboy的日志

问题

最近在使用Python的pymysql时,遇到了插入数据后数据丢失的问题:
现象是这样,执行Insert语句,返回1成功,但是数据库查看并没有此数据
当我用sqlyog连上数据库后,在sqlyog中执行插入语句就正常插入,并且发现自增的ID已经不是连续的
当我再次尝试用python插入一条后再用sqlyog插入,发现ID确实是已经自增过了。

解决方案

默认情况下,Connector/Python关闭autocommit
所以,在执行sql后,有必要使用connect</

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值