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 一定存在我不知道的高级用法,这样它才有存在的意义.但是我不清楚它到底是什么.
请大侠指点一二.
1
bombless 2017 年 3 月 4 日 via Android
貌似游标的作用是缓存执行过程中接收的信息,比如 last insert id 。这个貌似是数据库接口设计者那边设计的,不是数据库设计者设计的。
|
2
Shura 2017 年 3 月 4 日 via Android
https://en.m.wikipedia.org/wiki/Cursor_(databases),http://stackoverflow.com/questions/10646692/why-cursor-is-needed
上面两个链接的大意是游标能处理不同的行,一次能返回一个结果集,如果只是简单的循环,游标就没用。 |
3
julyclyde 2017 年 3 月 4 日
其实我也一直想问,但以前得到的回答大多数都是故弄玄虚……
|
4
iyaozhen 2017 年 3 月 4 日
我也有这个疑惑。还有什么时候该获取游标( cursor = db.cursor())?一开始获取一次?
|
5
Srar 2017 年 3 月 5 日
|
6
fs20 2017 年 3 月 5 日
这跟数据库的游标有啥关系?
这是 python 的东西…… |
7
yama88 2017 年 3 月 15 日
存储过程中有用吧
|