获取一个conn,需执行多条命令,每次执行一个sql后需要关闭cursor么?
2 回答
波斯汪
TA贡献1811条经验 获得超4个赞
可以一次执行多条。用python来举个栗子
import MySQLdb as mdb import sys conn = mdb.connect(host = 'localhost', user = 'root', passwd = '123456', db = 'test') cur = conn.cursor() cur.execute("insert into contact values('key1', 'value1')") cur.execute("select * from test") row_num = int(cur.rowcount)for i in range(row_num): row = cur.fetchone() print row #在数据操作完成之后,进行commit,完成数据库的数据更新 conn.commit() cur = conn.cursor() conn.close()
此问题与MySQL的存储引擎对事务的支持有关。 MySQL中有多种类型的存储引擎, 例如: MyISAM, InnoDB等。 MyISAM不支持事务处理, 而InnoDB是事务型数据库, 支持事务。比如InnoDB引擎, 所以对数据库数据的操作会在事先分配的缓存中进行, 只有在commit之后, 数据库的数据才会改变。
添加回答
举报
0/150
提交
取消