使用 mysql-connector-python 用 cnn = mysql.connector.connect 建立连接之后,创建一个 cursor = cnn.cursor 然后这个 cursor 一直不关闭一直用他去执行 cursor.execute(SELECT) 如果这期间数据库数据发生过了变化,取到的数据是最新的吗? 能具体讲一讲 cursor 在这里面的作用吗.
1
mashirozx 2018-02-09 19:56:49 +08:00 via Android
不是最新的,曾经写过一个脚本,创建一个 cursor 后一直 for 循环,按序号写入数据库,同时跑了多个进程,跑完后发现数据库出现了大量重复序号。。
|
2
lolizeppelin 2018-02-09 22:15:13 +08:00 via Android
这和 Python 没什么关系
游标的作用一是复用链接 类似 mq 在 connect 之上还有一层 channel 还有一个作用是大量数据查询只返回一部分 一直用一个游标查数据是可以的 |
3
vimiix 2018-02-10 11:24:23 +08:00
创建了一个 cursor 以后,建议是以完成一个事务就 commit 一下,不要一直用它,这样一直使用,并不会和数据库完成数据同步,如果操作太多,提交的时候会超时,造成部分数据更新,部分数据丢失,数据不一致,很麻烦,效率也低。
并且你握着 cursor 期间,数据库端发生改变,也没法和你这边同步。 |
4
vimiix 2018-02-10 11:25:29 +08:00
当然如果不涉及到写操作,只是查询的话,可以一直用。
|