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()的结果前,加入移动光标的操作,确保获取的结果是正确的结果
以上是我对最初的问题的解释。如有错误或不足之处请一定指出来,虚心学习。