python使用mysql connection获取数据感知不到数据变化问题

在做数据同步校验的时候,需要从mysql fetch数据和hbase的数据进行对比,发现即使mysql数据变化了,类似下面的代码返回的值还是之前的数据。抽取的代码大概如下:

 1 import MySQL
 2 
 3 conn = MySQL.connect(host = mysql_config['host'],
 4                     user = mysql_config['username'],
 5                     password = mysql_config['password'],
 6                     port = int(mysql_config['port']),
 7                     db = mysql_config['database'],
 8                     init_command = 'SET NAMES UTF8')
 9 
10 cur = conn.cursor()
11 
12 def get_data_from_mysql():
13     sql = "select * from table_a where ****"
14     cur.execute(sql)
15     result = []
16     for line in cur.fetall():
17         result.append(line)
18 
19     return result    

上面的代码,如果反复调用get_data_from_mysql函数,即使对于mysql数据库中同样一条数据变化,程序取出的还是变化之前的数据。

原因解释:这是mysql事务隔离的结果,InnoDB默认的隔离级别是可重复读(REPEATABLE READ),也就是在同一个事务中读取的值总是一样。所以为了感知到变化,必须重新获取一个事务(比方说关闭conneciton重新获取,或者调用commit,也可以改变mysql的事务隔离级别到READ COMMITED)。

 

参考资料:http://stackoverflow.com/questions/29680684/why-do-i-need-to-reconnect-to-the-database-to-see-changes-in-table-data

转载于:https://www.cnblogs.com/superhedantou/p/5785881.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值