首页
学习
活动
专区
圈层
工具
发布

mysql存储过程----游标

定义: 游标是用来存储查询结果集的数据类型,在存储过程和存储函数中可以使用游标对结果集进行循环处理,游标的使用包括游标声明、open、fetch和close,语法如下: 语法: 声明光标...: DECLARE 游标名称 CURSOR FOR 封装select语句; 开启游标(open): OPEN 游标名称; 获取游标中的数据(fetch) FETCH 游标名称 INTO var_name...关闭游标(close): close 游标名称; 示例: BEGIN -- 声明保存数据的变量 DECLARE class_id int(10); DECLARE class_name...VARCHAR(10); -- 声明一个名字为 cursor_result 游标 -- 游标值为class_info表中数据 DECLARE cursor_result CURSOR FOR...class_id,class_name; -- 查看结果 SELECT CONCAT('class_id=',class_id,'class_name=',class_name); -- 关闭游标

3.6K20

mysql存储过程之游标

MySQL5 中添加了存储过程的支持。  大多数SQL语句都是针对一个或多个表的单条语句。并非所有的操作都怎么简单。...经常会有一个完整的操作需要多条才能完成  存储过程简单来说,就是为以后的使用而保存的一条或多条MySQL语句的集合。可将其视为批文件。虽然他们的作用不仅限于批处理。...4 提高性能,因为使用存储过程比使用单条SQL语句要快 5 存在一些职能用在单个请求中的MySQL元素和特性,存储过程可以使用它们来编写功能更强更灵活的代码  换句话说3个主要好处简单、安全...大概看得懂,但是看到cursor游标之后有些懵,特此总结与一下 使用游标 MySQL5添加了对游标的支持  只能用于存储过程  直接上一个已经完善的存储过程,用于对表数据的copy DELIMITER...关于MySQL 5使用的 MySQL错误代码列表,请参阅 http://dev.mysql.com/doc/mysql/en/error-handling.html 。

3.4K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    存储过程与游标

    存储过程: 存储过程里的流程控制语句还有类似于switch分支语句,和while、loop等循环控制语句。 类似于switch分支语句的sql写法: ?...在存储过程里可以创建临时表,将计算出来的数据存储到临时表中: ? 在sql语句中没有自增自减的写法,只能写i=i+1;来代表i++。...带出值的存储过程,带出值的关键字是out: 将查询出来的值通过sname1带出 ?...游标:   游标是用于针对于SELECT语句拿值的,游标就是一个记录集的取值方法,需要在检索出来的行中前进或后退一行或多行的情况下就需要使用游标,所以游标是可以针对行进行操作的,游标写在存储过程中,游标使用...创建游标: 游标创建好后需要使用open打开,执行完后使用close关闭。 DELIMITER $$ CREATE    PROCEDURE `test123`.

    1.3K30

    Mysql 游标

    [mysql游标的用法及作用] 例子: 当前有三张表A、B、C其中A和B是一对多关系,B和C是一对多关系,现在需要将B中A表的主键存到C中; 常规思路就是将B中查询出来然后通过一个update语句来更新...显然是不现实的;最终找到写一个存储过程然后通过循环来更新C表, 然而存储过程中的写法用的就是游标的形式。...游标名称; 注:mysql存储过程每一句后面必须用;结尾,使用的临时字段需要在定义游标之前进行声明。...total+c; end loop; 在MySql中,造成游标溢出时会引发mysql预定义的NOT FOUND错误,所以在上面使用下面的代码指定了当引发not found错误时定义一个continue...until done end repeat; close cur; select total; END; call StatisticStore2(); 游标嵌套

    4.2K70

    MySQL游标

    游标也是一种面向过程的sql编程方法,所以一般在存储过程、函数、触发器、循环处理中使用。...游标相当于一个指针,这个指针指向select的第一行数据,可以通过移动指针来遍历后面的数据。 3、属性 在mysql中,游标可以在存储过程、函数、触发器和事件中使用。...业务操作:对遍历到的每行数据进行操作的过程,可以放置任何需要执行的执行的语句(增删改查) 关闭游标:游标使用完之后一定要释放(游标占用的内存较大)。 *使用的临时字段需要在定义游标之前进行声明。...# 当调用fetch的时候,会获取当前行的数据,如果当前行无数据,会引发mysql内部的 NOT FOUND错误 fetch 游标名称 into 变量列表; # 关闭游标 # 游标使用完毕之后一定要关闭...# 例如 declare continue handler for not found 表达式2 ,实质是利用mysql的异常处理,常常在游标上使用,来辅助判断游标数据是否遍历完了。

    3.5K10

    游标对于分页存储过程

    我个人认为最好的分页方法是: Select top 10 * from table where id>200 写成存储过程,上面的语句要拼一下sql语句,要获得最后大于的哪一个ID号 2。...那个用游标的方式,只适合于小数据量的表,如果表在一万行以上,就差劲了 你的存储过程还比不上NOT IN分页,示例: SELECT Top 10 * FROM Customers WHERE Customerid...游标是存放在内存中,很费内存. 游标一建立,就将相关的记录锁住,直到取消游标 游标提供了对特定集合中逐行扫描的手段,一般使用游标来逐行遍历数据,根据取出数据条件的不同进行不同的操作。...所以说,我个人的经验,就是一万上行上的表,不用游标.小数据量的表,适当的时候可以用游标 因为游标,遍历小数据量的行集还是不错的一个方法! 4。...用临时表自定义分页和使用游标自定义分页都不好!

    1K30

    深入解析MySQL(6)——存储过程、游标与触发器

    1.存储过程 概念:存储过程是一组预编译的SQL语句集合,存储在数据库中,可通过名称调用。...MySQL中,存储过程、函数等数据库对象的信息可以通过information_schema(数据库)中的routines(数据表)系统视图查询。...&条件处理程序 3.6.1 游标 游标(cursor):是一种数据库对象,用于在存储过程或函数中逐行处理查询结果集。...当游标遍历到结果集末尾时,会触发not found状态,需要结合条件处理程序结束循环,避免无限执行 语法: -- 声明游标 declare cursor_name cursor for 查询语句 -...- 打开游标 open cursor_name; -- 获取游标记录 fetch cursor_name into 3.6.2 条件处理程序 条件处理程序:用于捕获和处理SQL执行过程中的异常或特定状态

    19210

    MariaDB MariaDB、MySQL存储过程、游标基础应用举例说明

    DELIMITER // # 使用DELIMITER命令来把语句定界符从 ; 变为 // # 注意,定界符可以是其它符号,比如 $ ,但是不能为 \ ,因为它是转义字符 #说明,通常情况下,mysql...SELECT IF(@tmp=account_init, 'right', 'wrong') AS 'result'; #说明:用户变量(用户变量也归属局部变量)的定义:@变量名,, #注意: #1.mysql...中用户变量可不用事前声明,在用的时候直接用“@变量名”使用就可以了, #2.用户变量跟mysql客户端是绑定的,设置的变量,只对当前用户使用的客户端生效 #说明:用SET给变量赋值: SET 变量...(带参数) # "场景1"不用游标的等价实现 # 创建存储过程 DROP PROCEDURE IF EXISTS proc_varify_profit_sharing; DELIMITER...// CREATE PROCEDURE proc_varify_profit_sharing( userID BIGINT, # 注意,当存储过程参数如果用于存储过程中,表查询语句的WHERE子句

    1.4K40

    MySQL高级篇-游标

    MySQL中的游标 1.什么是游标   虽然我们也可以通过筛选条件 WHERE 和 HAVING,或者是限定返回记录的关键字 LIMIT 返回一条记录,但是,却无法在结果集中像指针一样,向前定位一条记录...这里游标充当了指针的作用 ,我们可以通过操作游标来对数据行进行操作。   MySQL中游标可以在存储过程和函数中使用。...FETCH cur_score INTO stu_id, grade ; 注意:游标的查询结果集中的字段数,必须跟 INTO 后面的变量数一致,否则,在存储过程执行的时候,MySQL 会提示错误。...因为游标会占用系统资源 ,如果不及时关闭,游标会一直保持到存储过程结束,影响系统运行的效率。而关闭游标的操作,会释放游标占用的系统资源。   ...,@s_count) ; SELECT @s_count; 4.小结   游标是 MySQL 的一个重要的功能,为 逐条读取 结果集中的数据,提供了完美的解决方案。

    3.9K50

    MySQL学习14_游标

    游标 SQL检索操作返回的是一行或者多行称为结果集的行。 有时候我们是需要在检索的结果中,前进或者后退一行或者多行,这个时候需要使用游标cursor。...规定范围,使得游标对创建它的特定请求或者所有请求可访问 ---- 使用游标 使用步骤 declare:在使用游标之前,必须先进行声明 open:一旦声明了游标,就必须打开游标 对于填有数据的游标,根据需要取出检索的各行...close:在结束的时候,必须关闭游标;有的DBMS还需要释放游标 创建、打开游标 使用declare语句创建游标 使用open语句进行打开 -- 创建游标 declare CustCursor...访问游标数据使用的关键字是fetch,功能: 检索哪些行 从何处开始检索 将检索的结果置于何处 闭游标 关闭游标的关键词是close。...import pymysql host:主机名或者IP地址 port:默认是3306 user:用户名 passwd:user账户登录mysql的密码 db:创建的数据库 charset:防止中文出错

    2.7K10

    Postgresql游标编译过程和编译结果

    相关 《Postgresql游标使用介绍(cursor)》 《Postgresql游标编译过程&结果记录》 记录游标编译后的状态,供日后查询。...这里只记录了编译过程,缺失执行过程,执行过程放在后面两大章节介绍:SPI系统 和 Portal系统。...案例 《Postgresql游标使用介绍(cursor)》中的案例: drop table tf1; create table tf1(c1 int, c2 int, c3 varchar(32),...,这里需要统一保存到一个row中 需要注意的是row只是一个总集,具体的变量还会单独记录在plpgsql_Datums中 PLpgSQL_var游标 游标类型变量也是使用PLpgSQL_var来保存...,特别的是会启动cursor_xxx的几个变量保存信息 游标类型的cursor_options用于记录游标的行为模式:使用下面的标志位 #define CURSOR_OPT_BINARY 0x0001

    1K10

    ⑩⑤【DB】详解MySQL存储过程:变量、游标、存储函数、循环,判断语句、参数传递..

    变量 ①系统变量 系统变量: ⚪系统变量:是MySQL服务器提供,不是用户定义的,属于服务器层面。分为全局变量(GLOBAL)、会话变量(SESSION)。...MySQL服务重新启动后,所设置的全局变量都会重置,想要不失效,可以在配置文件/etc/my.cnf文件中配置。...游标 和 条件处理程序 ①游标 cursor cursor: 游标(CURSOR): 是用来存储查询结果集的数据类型,在存储过程和函数中可以使用游标对结果集进行循环的处理。...游标的声明: DECLARE 游标名称 CURSOR FOR 查询语句; 打开游标: OPEN 游标名称; 获取游标记录: FETCH 游标名称 INTO 变量1[,变量2,...]; 关闭游标: CLOSE...游标名称; ②条件处理程序 Handler Handler: 条件处理程序(Handler): 可以用来定义在流程控制结构执行过程中遇到问题时相应的处理步骤 。

    3.2K100
    领券