1、什么是游标?
一张图讲述游标的功能:
图示说明:
2、使用游标的好处?
如果不使用游标功能,直接使用select查询,会一次性将结果集打印到屏幕上,你无法针对结果集做第二次编程。使用游标功能后,我们可以将得到的结果先保存起来,然后可以随意进行自己的编程,得到我们最终想要的结果集。
3、利用python连接数据库,经常会使用游标功能
1)以python连接mysql数据库为例
2)使用游标的操作步骤
① 连接数据库,创建一个数据库对象
db = pymysql.connect(host='localhost',user='root',db='huangwei', password='123456',port=3306,charset='utf8')
注意:我们要操作的是huangwei这个数据库中的表,因此在连接的时候使用db这个参数来指明要使用哪一个数据库;由于mysql数据库就装在本机上,因此可以写localhost,当然你也可以写成主机名,或者主机ip;
② 开启游标功能,创建游标对象
# 这里使用的是数据库对象db中的cursor()方法, cursor = db.cursor()
③ 使用execute()方法,执行SQL语句
cursor.execute('select sname,ssex from student')
注意:当开启游标功能执行这个SQL语句后,系统并不会将结果直接打印到频幕上,而是将上述得到的结果,找个地方存储起来,提供一个游标接口给我们,当你需要获取数据 的时候,就可以从中拿数据。
④ 使用fetchone()或fetchall()获取数据
# 一次性获取一条数据 a = cursor.fetchone() # 一次性获取所有数据 a = cursor.fetchall()
注意:使用游标获取数据,需要用一个变量将结果存储起来,才能被我们拿来做二次使用,这里在下面的案例中会体现出来。
⑤ 断开数据库,释放资源
db.close()
3)案例讲解
需求:以操做huangwei数据库中的student表为例 。完成【筛选出女生,同时将sname以这种形式输出“我叫周梅,我是一个学生!”】这个需求。
① student表
② 使用fetchone()方法,获取SQL查询结果集中的数据
db = pymysql.connect(host='localhost',user='root',db='huangwei', password='123456',port=3306,charset='utf8') cursor = db.cursor() cursor.execute('select count(*) from student') aa = cursor.fetchone() print(aa) # 注意这一句一定是在循环之外,不能放到循环里面。想想这是为什么? cursor.execute('select sname,ssex from student') for i in range(aa[0]): a,b = cursor.fetchone() if b == "女": a = "我叫{},我是一个学生!".format(a) print(a) db.close()
结果如下:
③ 使用fetchall()html" target="_blank">方法,获取SQL查询结果集中的数据
db = pymysql.connect(host='localhost',user='root',db='huangwei', password='123456',port=3306,charset='utf8') cursor = db.cursor() cursor.execute('select sname,ssex from student') aa = cursor.fetchall() # print(aa) for a,b in aa: if b == "女": a = "我叫{},我是一个学生!".format(a) print(a) db.close()
结果如下:
④ 结果分析
通过上述操作可以发现,这种游标功能可以帮助我们对SQL语句得到的结果集,进行二次开发,然后通过灵活的python语法,得到任何我们最终想要的结果集。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
大家好,今天给大家介绍一个非常热门的技术,同时也是面试的时候面试官特别喜欢问的一个话题,那就是 SpringCloudAlibaba 的底层原理。 现在大家都知道,SpringCloudAlibaba 风靡 Java 开发行业,各个公司都在用这套技术,所以咱们 Java 工程师出去面试,面试官对 SpringCloudAlibaba 都搞成了面试必问选项了,但凡面试,总会有面试官问问:“兄弟,Sp
主要内容:一、场景引入,问题初现,二、volatile的作用及背后的原理,三、总结 & 提醒一、场景引入,问题初现 很多同学出去面试,都会被问到一个常见的问题:说说你对volatile的理解? 不少初出茅庐的同学可能会有点措手不及,因为可能就是之前没关注过这个。但是网上百度一下呢,不少文章写的很好,但是理论扎的太深,文字太多,图太少,让人有点难以理解。 基于上述痛点,这篇文章尝试站在年轻同学的角度,用最简单的大白话,加上多张图给大家说一下,volatile到底是什么? 当然本文不会把理论
本文向大家介绍彻底搞懂Python字符编码,包括了彻底搞懂Python字符编码的使用技巧和注意事项,需要的朋友参考一下 不论你是有着多年经验的 Python 老司机还是刚入门 Python 不久,你一定遇到过UnicodeEncodeError、UnicodeDecodeError 错误,每当遇到错误我们就拿着 encode、decode 函数翻来覆去的转换,有时试着试着问题就解决了,有时候怎么试
本文向大家介绍彻底搞懂PHP 变量结构体,包括了彻底搞懂PHP 变量结构体的使用技巧和注意事项,需要的朋友参考一下 PHP5 中的 zval 多数文章,在提到PHP5 变量结构体的时候,都提到:sizeof(zval) == 24, sizeof(zvalue_value) == 16,实际上这个论述并不准确,在 CPU 为 64bit 时,这个结果是正确的。 但当 CPU 为32bit 时: s
本文向大家介绍python 3.6 +pyMysql 操作mysql数据库(实例讲解),包括了python 3.6 +pyMysql 操作mysql数据库(实例讲解)的使用技巧和注意事项,需要的朋友参考一下 版本信息:python:3.6 mysql:5.7 pyMysql:0.7.11 测试代码: 测试表: 执行结果: 以上这篇python 3.6 +pyMysql 操作mysql数据库(实
本文向大家介绍python操作mysql数据库,包括了python操作mysql数据库的使用技巧和注意事项,需要的朋友参考一下 一、数据库基本操作 1. 想允许在数据库写中文,可在创建数据库时用下面命令 create database zcl charset utf8; 2. 查看students表结构 desc students; 3. 查看创建students表结构的语句 show creat
本文向大家介绍彻底搞懂JavaScript中的apply和call方法(必看),包括了彻底搞懂JavaScript中的apply和call方法(必看)的使用技巧和注意事项,需要的朋友参考一下 call和apply都是为了改变某个函数运行的context上下文而存在的,即为了改变函数体内部this的指向。因为JavaScript的函数存在定义上下文和运行时上下文以及上下文是可以改变的概念。 回到目录
本文向大家介绍ASP.NET操作MySql数据库的实例代码讲解,包括了ASP.NET操作MySql数据库的实例代码讲解的使用技巧和注意事项,需要的朋友参考一下 一、把MySql.Data.dll放到BIN目录下。 二、这是aspx.cs的全部源码,修改参数直接运行即可! 以上所述是小编给大家介绍的ASP.NET操作MySql数据库的实例代码讲解,希望对大家有所帮助,如果大家有任何疑问请给我留