为了账号安全,请及时绑定邮箱和手机立即绑定

mysql conn执行后 需要每次关闭cursor么?

mysql conn执行后 需要每次关闭cursor么?

慕仙森 2018-07-21 21:07:14
获取一个conn,需执行多条命令,每次执行一个sql后需要关闭cursor么?
查看完整描述

2 回答

?
繁星点点滴滴

TA贡献1803条经验 获得超3个赞

一般是给数据库连接池来操作每个连接实例的开和闭
如果是自己获取的话,在方法执行最后,最好关闭。

查看完整回答
反对 回复 2018-07-28
?
波斯汪

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之后, 数据库的数据才会改变。


查看完整回答
反对 回复 2018-07-28
  • 2 回答
  • 0 关注
  • 4903 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信