Python 操作数据库 cursor 的问题.

2018-02-09 18:08:59 +08:00
 LemonFirst

使用 mysql-connector-python 用 cnn = mysql.connector.connect 建立连接之后,创建一个 cursor = cnn.cursor 然后这个 cursor 一直不关闭一直用他去执行 cursor.execute(SELECT) 如果这期间数据库数据发生过了变化,取到的数据是最新的吗? 能具体讲一讲 cursor 在这里面的作用吗.

4594 次点击
所在节点    Python
4 条回复
mashirozx
2018-02-09 19:56:49 +08:00
不是最新的,曾经写过一个脚本,创建一个 cursor 后一直 for 循环,按序号写入数据库,同时跑了多个进程,跑完后发现数据库出现了大量重复序号。。
lolizeppelin
2018-02-09 22:15:13 +08:00
这和 Python 没什么关系

游标的作用一是复用链接 类似 mq 在 connect 之上还有一层 channel

还有一个作用是大量数据查询只返回一部分

一直用一个游标查数据是可以的
vimiix
2018-02-10 11:24:23 +08:00
创建了一个 cursor 以后,建议是以完成一个事务就 commit 一下,不要一直用它,这样一直使用,并不会和数据库完成数据同步,如果操作太多,提交的时候会超时,造成部分数据更新,部分数据丢失,数据不一致,很麻烦,效率也低。

并且你握着 cursor 期间,数据库端发生改变,也没法和你这边同步。
vimiix
2018-02-10 11:25:29 +08:00
当然如果不涉及到写操作,只是查询的话,可以一直用。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/429833

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX