什么是 cursor/游标?

2017-03-04 19:25:52 +08:00
 chaleaoch

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 一定存在我不知道的高级用法,这样它才有存在的意义.但是我不清楚它到底是什么.

请大侠指点一二.

1459 次点击
所在节点    数据库
7 条回复
bombless
2017-03-04 20:24:29 +08:00
貌似游标的作用是缓存执行过程中接收的信息,比如 last insert id 。这个貌似是数据库接口设计者那边设计的,不是数据库设计者设计的。
Shura
2017-03-04 21:29:22 +08:00
https://en.m.wikipedia.org/wiki/Cursor_(databases),http://stackoverflow.com/questions/10646692/why-cursor-is-needed
上面两个链接的大意是游标能处理不同的行,一次能返回一个结果集,如果只是简单的循环,游标就没用。
julyclyde
2017-03-04 22:29:07 +08:00
其实我也一直想问,但以前得到的回答大多数都是故弄玄虚……
iyaozhen
2017-03-04 22:41:28 +08:00
我也有这个疑惑。还有什么时候该获取游标( cursor = db.cursor())?一开始获取一次?
Srar
2017-03-05 00:24:01 +08:00
fs20
2017-03-05 23:21:24 +08:00
这跟数据库的游标有啥关系?
这是 python 的东西……
yama88
2017-03-15 14:03:14 +08:00
存储过程中有用吧

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

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

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

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

© 2021 V2EX