今天在尝试用下面的python代码对MySQL进行数据的插入、更新和删除时, 忽然发现代码执行成功, 经过代码查询也显示数据已经插入或更新, 可是当我在MySQL客户端经过SQL语句查询时, 数据库中的数据一点变化都没有。 又反复实验了屡次, 结果都是同样的。python
1 #!/usr/bin/python 2 #Program: 3 # to get some information from mysql 4 import MySQLdb as mdb 5 import sys 6 7 conn = mdb.connect(host = 'localhost', user = 'root', passwd = '8023xue0526', db = 'contact') 8 9 cur = conn.cursor() 10 cur.execute("insert into contact values('222221', 'ni')") 11 cur.execute("select * from contact") 12 row_num = int(cur.rowcount) 13 for i in range(row_num): 14 row = cur.fetchone() 15 print row 16 cur = conn.cursor() 17 conn.close()
经过在网上查找, 最终才有了一点眉目, 此问题与MySQL的存储引擎对事务的支持有关。 原来MySQL中有多种类型的存储引擎, 例如: MyISAM, InnoDB等。 MyISAM不支持事务处理, 而InnoDB是事务型数据库, 支持事务。 个人MySQL的默认存储引擎就是InnoDB, 因此对数据库数据的操做会在事先分配的缓存中进行, 只有在commit以后, 数据库的数据才会改变。 修改后的代码以下:mysql
1 #!/usr/bin/python 2 #Program: 3 # to get some information from mysql 4 import MySQLdb as mdb 5 import sys 6 7 conn = mdb.connect(host = 'localhost', user = 'root', passwd = '8023xue0526', db = 'contact') 8 9 cur = conn.cursor() 10 cur.execute("insert into contact values('222221', 'ni')") 11 cur.execute("select * from contact") 12 row_num = int(cur.rowcount) 13 for i in range(row_num): 14 row = cur.fetchone() 15 print row 16 #在数据操做完成以后,进行commit,完成数据库的数据更新 17 conn.commit() 18 cur = conn.cursor() 19 conn.close()
可是之前在用MySQL C API 对数据库进行数据操做的时候没有这状况, 经过查看资料, autocommit变量的状态决定是否每次对数据操做以后自动commit, 在MySQL客户端里autocommit=ON时, 在客户端输入SQL语句, 每次都会自动执行一次commit。 我查看了本身的MySQL的autocommit为ON, 可是仍是没搞清楚为何同在InnoDB存储引擎下, autocommit=ON, 用C API 无需commit, 而用Python API 必须commit。 看到此文章的网友若是知道, 多谢你能给我解惑。。sql