首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python 学习手册
Python Cookbook
Python 基础教程
Python Sites
PyPI - Python Package Index
http://www.simple-is-better.com/
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
V2EX  ›  Python

Python 操作数据库 cursor 的问题.

  •  
  •   LemonFirst · 106 天前 · 1718 次点击
    这是一个创建于 106 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    4 回复  |  直到 2018-02-10 11:25:29 +08:00
        1
    mashirozx   106 天前 via Android
    不是最新的,曾经写过一个脚本,创建一个 cursor 后一直 for 循环,按序号写入数据库,同时跑了多个进程,跑完后发现数据库出现了大量重复序号。。
        2
    lolizeppelin   106 天前 via Android
    这和 Python 没什么关系

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

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

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

    并且你握着 cursor 期间,数据库端发生改变,也没法和你这边同步。
        4
    vimiix   106 天前
    当然如果不涉及到写操作,只是查询的话,可以一直用。
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   鸣谢   ·   1689 人在线   最高记录 3541   ·  
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.1 · 77ms · UTC 08:06 · PVG 16:06 · LAX 01:06 · JFK 04:06
    ♥ Do have faith in what you're doing.
    沪ICP备16043287号-1