mysql -- 存储过程,游标

错误异常处理:

语法如下:

declare

{exit | continue}

handler for

{error-number | {sqlstate error-string} | condition }

sql statement

这个语句指定了每个可以处理一个或多个条件的处理程序。如果产生一个或多个条件,则指定的语句将被执行,对于一个continue处理程序,当前子程序的执行将在执行处理程序语句之后继续。对于exit处理程序,当前的begin...end 复合语句的执行将被终止。

实例一:

DELIMITER $$

USE `csp` $$

DROP PROCEDURE IF EXISTS `curdemo` $$

CREATE DEFINER = `root` @`%` PROCEDURE `curdemo` (IN p_source VARCHAR (100))
BEGIN
  -- 需要定义接收游标数据的变量
  DECLARE done INT DEFAULT 0 ;
  -- 自定义变量
  DECLARE var_price DOUBLE DEFAULT NULL ;
  DECLARE var_pay_time TIMESTAMP DEFAULT NULL ;
  DECLARE var_product VARCHAR (100) DEFAULT NULL ;
  DECLARE var_source VARCHAR (100) DEFAULT NULL ;
  -- 声明游标
  DECLARE cur CURSOR FOR
  -- 作用于哪个语句
  SELECT
    price,
    pay_time,
    product,
    source
  FROM
    cms_aw_order
  WHERE source = p_source ;
  -- 设置结束标志
  -- 这条语句定义了一个 CONTINUE HANDLER,它是在条件出现时被执行的代码。这里,它指出当 SQLSTATE ‘02000‘出现时,SET done=1 。SQLSTATE ‘02000‘是一个未找到条件,当REPEAT由于没有更多的行供循环而不能继续时,出现这个条件
  DECLARE CONTINUE HANDLER FOR SQLSTATE ‘02000‘ SET done = 1 ;
  -- 打开游标
  OPEN cur ;
  -- 使用repeat循环语法
  REPEAT
    -- 批读取数据到指定变量上
    FETCH cur INTO var_price,
    var_pay_time,
    var_product,
    var_source ;
    -- 进行逻辑操作
    INSERT INTO cms_aw_order_copy (price, pay_time, product, source)
    VALUES
      (
        var_price,
        var_pay_time,
        var_product,
        var_source
      ) ;
    -- 循环结束条件
    UNTIL done
  END REPEAT ;
  -- 关闭游标
  CLOSE cur ;
END $$

DELIMITER ;

实例二:

需求:编写存储过程,使用游标,把uid为偶数的记录逐一更新用户名。

delimiter $$
create procedure testf(IN my_userId varchar(32))
begin
  declare stopflag int default 0;
  declare my_uname varchar(32) default ‘‘;
  declare uname_cur CURSOR for select uname from temp_user where uid%2=0;
  #1 游标是保存查询结果的临时内存区域
  #2 游标变量uname_cur保存了查询的临时结果,实际上就是查询结果集
  declare continue handler for not found set stopflag=1;
  #3 声明句柄,当游标变量中保存的结果都查询一遍(遍历),到达结尾,就把变量stopflag设置为1 用于循环中判断是否遍历结束
  open uname_cur; # 打开游标
  fetch uname_cur into my_uname; # 游标向前走一步,取出一条记录放到变量my_uname中。
  while(stopflag=0) DO # 如果游标还没到结尾,就继续循环
  begin
    update temp_user set uname=CONCAT(my_uname,‘_cur‘) where uname=my_uname;
    fetch uname_cur into my_uname;
  end;
  end while;
  close uname_cur;
end;
$$
delimiter ;

原文地址:https://www.cnblogs.com/daijiabao/p/11293932.html

时间: 2024-10-16 06:47:32

mysql -- 存储过程,游标的相关文章

MySQL 存储过程/游标/触发器/事务

来源:http://www.cnblogs.com/zhuyp1015/p/3575823.html 将会用到的几个表 mysql> DESC products; +------------+--------------+------+-----+---------+----------------+| Field      | Type         | Null | Key | Default | Extra          |+------------+--------------+-

mysql存储过程 --游标的使用 取每行记录 (多字段)

delimiter $ create PROCEDURE phoneDeal() BEGIN DECLARE id varchar(64); -- id DECLARE phone1 varchar(16); -- phone DECLARE password1 varchar(32); -- 密码 DECLARE name1 varchar(64); -- id -- 遍历数据结束标志 DECLARE done INT DEFAULT FALSE; -- 游标 DECLARE cur_acco

MySQL 存储过程游标

一.创建游标 游标用declare语句创建.如下面的例子所示: create procedure test2() begin declare cursorTest cursor for select * from allIntersection; end; 二.打开.关闭游标 打开游标 open cursorTest; 关闭游标 close cursorTest; CLOSE释放游标使用的所有内部内存和资源,因此在每个游标不再需要时都应该关闭.在一个游标关闭后,如果没有重新打开,则不能使用它.但

mysql 存储过程 游标 判断游标是否为空

BEGIN DECLARE id long; DECLARE Done INT DEFAULT 0; DECLARE cashamount DECIMAL(10,2) DEFAULT 0.00; DECLARE scorecamount INT DEFAULT 0; DECLARE userids CURSOR FOR SELECT userid from info_user where isreal = 1; DECLARE CONTINUE HANDLER FOR SQLSTATE '020

转 mysql 存储过程初探

https://www.cnblogs.com/qmfsun/p/4838032.htmlMySQL命令执行sql文件的两种方法 https://www.cnblogs.com/mark-chan/p/5384139.html CREATE PROCEDURE GreetWorld() SELECT CONCAT(@greeting,' World');SET @greeting='Hello';CALL GreetWorld(); https://blog.csdn.net/shaochens

mysql中游标在存储过程中的详细用法

昨天写的一个东东,分享下给大家. drop PROCEDURE  if exists sp_cleanUserData; CREATE  PROCEDURE `sp_cleanUserData`() BEGIN /*定义游标*/ declare v_dt bigint(20) default 0 ; declare v_num INT DEFAULT 0; /*游标循环到末尾时给定义的常量赋值*/ declare cur_userId   CURSOR FOR select  userId fr

mysql存储过程之游标遍历数据表

原文:mysql存储过程之游标遍历数据表 今天写一个mysql存储过程,根据自己的需求要遍历一个数据表,因为对存储过程用的不多,语法不甚熟悉,加之存储过程没有调试环境,花了不少时间才慢慢弄好,故留个痕迹. 1 BEGIN 2 DECLARE Done INT DEFAULT 0; 3 4 DECLARE CurrentLingQi INT; 5 6 DECLARE ShizuName VARCHAR(30); 7 /* 声明游标 */ 8 DECLARE rs CURSOR FOR SELECT

Mysql 存储过程使用游标

-- 完整例子 CREATE PROCEDURE test BEGIN -- 定义参数    DECLARE _id INT; -- 定义游标    DECLARE no_more_products INT DEFAULT 0;    DECLARE RESULT_test CURSOR FORSELECT num1 from numtest; -- 如果NOT FOUND游标DECLARE  CONTINUE HANDLER FOR NOT FOUND  SET  no_more_produc

MYSQL进阶学习知识拓展一:MySQL 存储过程之游标!

一.MySQL游标的概念 游标介绍: MySQL的游标(cursor)是一个重要的概念,通过查找资料与自己的理解,主要得出以下几点关于自己的理解. 有数据缓冲的思想:游标的设计是一种数据缓冲区的思想,用来存放SQL语句执行的结果. 先有数据基础:游标是在先从数据表中检索出数据之后才能继续灵活操作的技术.   类似于指针:游标类似于指向数据结构堆栈中的指针,用来pop出所指向的数据,并且只能每次取一个. 游标优缺点: 游标的优点: 因为游标是针对行操作的,所以对从数据库中select查询得到的每一

MySQL存储过程和游标

一.存储过程 什么是存储过程,为什么要使用存储过程以及如何使用存储过程,并且介绍创建和使用存储过程的基本语法. 什么是存储过程: 存储过程可以说是一个记录集,它是由一些T-SQL语句组成的代码块,这些T-SQL语句代码像一个方法一样 实现一些功能(对单表或多表的增删改查),然后再给这个代码块取一个名字,在用到这个功能的时候调用 他就行了. 存储过程的好处: 由于数据库执行动作时,是先编译后执行的.然而存储过程是一个编译过的代码块,所以执行效率要比 T-SQL语句高. 一个存储过程在程序在网络中交