美文网首页
Python_关于self.cur.scroll()的使用理解

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

作者: 蒹葭苍苍蛋 | 来源:发表于2017-09-01 15:59 被阅读0次

    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()的使用理解

          本文链接:https://www.haomeiwen.com/subject/kpxcjxtx.html