推荐学习书目
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 · Feb 9, 2018 · 5088 views
    This topic created in 3017 days ago, the information mentioned may be changed or developed.

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

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

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

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

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

    并且你握着 cursor 期间,数据库端发生改变,也没法和你这边同步。
    vimiix
        4
    vimiix  
       Feb 10, 2018
    当然如果不涉及到写操作,只是查询的话,可以一直用。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3257 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 35ms · UTC 03:15 · PVG 11:15 · LAX 20:15 · JFK 23:15
    ♥ Do have faith in what you're doing.