python中scroll的用法_Python_关于self.cur.scroll()的使用理解

本文详细介绍了Python操作MySQL时,如何使用self.cur.scroll()方法来管理游标。通过实例展示了scroll()在不同模式下的功能,包括相对移动和绝对移动,并解释了为何在某些情况下需要将游标移动回初始位置,以确保获取正确结果。
摘要由CSDN通过智能技术生成

python操作mysql,定义了一个查询多条数据的方法selectAll:

# 查询表中多条数据

def selectAll(self, condition):

try:

self.cur.execute(condition) # 在游标下执行语句

self.cur.scroll(0, mode='absolute') # 光标回到初始位置

results = self.cur.fetchall() # 返回游标中所有结果

except pymysql.Error as e:

results = "SQL10001" # 数据库执行错误

print("Mysql Error %d: %s" % (e.args[0], e.args[1]))

# print("error_info: %s" %e)

finally:

return results

【问题】关于self.cur.scroll()方法,为什么需要移动光标回到初始位置?把这条语句注释了输出结果也不变啊?

self.cur.scroll(0, mode='absolute') # 光标回到初始位置

【查询1】移动光标,scroll()方法概述

scroll(value, mode)

mode缺省值为'relative',代表相对移动。

当mode='relative'时,value就是移动的长度,value>0向后移动(从位置0移动到位置2),value<0向前移动(比如从位置2移动到位置0)

self.cur.scroll(-2, 'relative')

可以缩写为:

self.cur.scroll(-2)

当mode='absolute'时,代表绝对移动,value就代表移动的绝对位置,value=0就代表移动到位置0处,就是结果集开头,value=3就是移动到位置3处,也就是第4条记录处。

self.cur.scroll(0, 'absolute')

【查询2】scroll()方法使用实例

存在数据库表如下:

pdx

name

sex

dept

1

张三

1

市场部

2

李四

1

人事部

3

陈灵

0

技术部

4

王萌

0

财务部

实例1

self.cur.execute("select * from yui_user;") # 在游标下执行语句

results_crash = self.cur.fetchall() # 返回游标中所有结果

results = self.cur.fetchall() # 返回游标中所有结果

print(results_crash )

print(results)

由于第二行代码首先取出了所有结果,游标也相应的从结果集开始位置移动到结果集末尾,所以第二次使用fetchall()取出的就是空值。

>>> ((1, '张三', '1', '市场部'),

(2, '李四', '1', '人事部'),

(3, '陈灵', '0', '技术部'),

(4, '王萌', '0', '财务部'))

>>>()

实例2

self.cur.execute("select * from yui_user;") # 在游标下执行语句

results_crash = self.cur.fetchall() # 返回游标中所有结果

self.cur.scroll(-2, 'relative') # 光标向前移动2个位置

results = self.cur.fetchall() # 返回游标中所有结果

print(results_crash )

print(results)

与实例1不同的就是在第三行添加了scroll()方法移动光标,此时光标移动到pdx为3的位置,再次使用fetchall()取出的即为最后两条记录。

>>> ((1, '张三', '1', '市场部'),

(2, '李四', '1', '人事部'),

(3, '陈灵', '0', '技术部'),

(4, '王萌', '0', '财务部'))

>>>((3, '陈灵', '0', '技术部'),

(4, '王萌', '0', '财务部'))

【我对问题的解释】

单独把try执行部分拎出来:

try:

self.cur.execute(condition) # 在游标下执行语句

self.cur.scroll(0, mode='absolute') # 光标回到初始位置

results = self.cur.fetchall() # 返回游标中所有结果

由于第三句 results = self.cur.fetchall()之前没有执行其他从游标中获取结果的语句,即光标没有进行移动。因此无论有没有把光标移动到初始位置这一条语句,输出结果是不变的(目前结果也是正确的)。

但如果在results = self.cur.fetchall()之前再加入别的fetchall()或fetchone(),那就必须移动光标了,否则结果不正确。为了避免出现这种情况,每次在需要最后输出正确的fetchall()的结果前,加入移动光标的操作,确保获取的结果是正确的结果

以上是我对最初的问题的解释。如有错误或不足之处请一定指出来,虚心学习。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值