Python_关于self.cur.scroll()的使用理解

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()的结果前,加入移动光标的操作,确保获取的结果是正确的结果

附录学习scroll()方法时的参考文章:
http://www.cnblogs.com/hbsygfz/p/4545208.html

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

你可能感兴趣的:(Python_关于self.cur.scroll()的使用理解)