V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
chaleaoch
V2EX  ›  数据库

什么是 cursor/游标?

  •  
  •   chaleaoch · Mar 4, 2017 · 2082 views
    This topic created in 3344 days ago, the information mentioned may be changed or developed.

    cursor 存在的意义是什么. 例如我 connect 一个 db 之后,还要在获取一个 cursor,然后用这个句柄去 execute 或者 fetchall 什么的.最后 close cursor,close db,

    在这里我们会发现,cursor 和 db 的功能是重复的.open/connect 了两遍,close 了两遍.

    是不是有什么我不知道的高级用法?导致这个游标是有存在意义的?

    谢谢.

    举个例子,python code:

    db01 = MySQLdb.connect(*****)
    cursor = db01.cursor(******)
    cursor.execute('select * from ***')
    1_list = cursor.fetchall()
    cursor.execute(sql1)
    2_list = cursor.fetchall()
    cursor.execute(sql2)
    3_list = cursor.fetchall()
    cursor.close()
    db01.close()
    

    所以我猜测,cursor 一定存在我不知道的高级用法,这样它才有存在的意义.但是我不清楚它到底是什么.

    请大侠指点一二.

    7 replies    2017-03-15 14:03:14 +08:00
    bombless
        1
    bombless  
       Mar 4, 2017 via Android
    貌似游标的作用是缓存执行过程中接收的信息,比如 last insert id 。这个貌似是数据库接口设计者那边设计的,不是数据库设计者设计的。
    Shura
        2
    Shura  
       Mar 4, 2017 via Android
    https://en.m.wikipedia.org/wiki/Cursor_(databases),http://stackoverflow.com/questions/10646692/why-cursor-is-needed
    上面两个链接的大意是游标能处理不同的行,一次能返回一个结果集,如果只是简单的循环,游标就没用。
    julyclyde
        3
    julyclyde  
       Mar 4, 2017
    其实我也一直想问,但以前得到的回答大多数都是故弄玄虚……
    iyaozhen
        4
    iyaozhen  
       Mar 4, 2017
    我也有这个疑惑。还有什么时候该获取游标( cursor = db.cursor())?一开始获取一次?
    fs20
        6
    fs20  
       Mar 5, 2017
    这跟数据库的游标有啥关系?
    这是 python 的东西……
    yama88
        7
    yama88  
       Mar 15, 2017
    存储过程中有用吧
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   798 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 55ms · UTC 20:33 · PVG 04:33 · LAX 13:33 · JFK 16:33
    ♥ Do have faith in what you're doing.