V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
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
LemonFirst
V2EX  ›  Python

Python 操作数据库 cursor 的问题.

  •  
  •   LemonFirst · 2018-02-09 18:08:59 +08:00 · 4665 次点击
    这是一个创建于 2473 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

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

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

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

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

    并且你握着 cursor 期间,数据库端发生改变,也没法和你这边同步。
    vimiix
        4
    vimiix  
       2018-02-10 11:25:29 +08:00
    当然如果不涉及到写操作,只是查询的话,可以一直用。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2867 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 14:33 · PVG 22:33 · LAX 06:33 · JFK 09:33
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.