问题
用 MySQLdb 操作数据库,插入数据之后发现数据库中依然为空,不知原因为何。
开启 mysqld 的 log 设置项之后发现日志文档中更有执行 sql 语句,直接复制语句在客户端中执行也没有问题,那么为什么通过 MySQLdb 的插入全部没有结果呢?
我怀疑是 MySQLdb 的问题,在日志文件中仔细的看了一遍运行的所有sql 语句,在建立连接之后还运行了这句:set autocommit=0。这句话的嫌疑很大,因为这个涉及到一个语句提交执行的问题,而且对于 commit 我有点印象,好像以前学习 MySQLdb 的时候,特意注意到了这点。不管怎样,这就找准了关键字:MySQLdb autocommit
根据网上搜到的结果,可以大概了解到,MySQLdb 在连接后关闭了自动提交,自动提交对于 innodb 引擎很重要,没有这个设置,innodb 引擎就不会真正执行语句。
解决办法
- 语句末尾加上
COMMIT;
- 运行完语句,至少在关闭数据库之前提交一下,如:
conn.commit()
- 数据库连接建立之后,设置自动提交,如:
conn.autocommit(1)
只是不知道为什么 InnoDB 会这样,可能是因为这是一个事务型数据库引擎,没有提交就不会在服务器上执行,只会缓存在客户端上的缘故吧!
参考资料与拓展阅读
- MySQLdb 插入数据失败?
- CSDN,gukesdo的专栏,MySQLdb Python模块autocommit属性测试及测试过程中关于数据库连接的理解