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