mysql-存储过程 使用游标获取数据集并且操作

Posted 邢朝阳

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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_account CURSOR FOR select phone,password,name from account_temp;
    -- 将结束标志绑定到游标
    DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
    
    -- 打开游标
    OPEN  cur_account;     
    -- 遍历
    read_loop: LOOP
            -- 取值 取多个字段
            FETCH  NEXT from cur_account INTO phone1,password1,name1;
            IF done THEN
                LEAVE read_loop;
             END IF;
 
        -- 你自己想做的操作
        insert into account(id,phone,password,name) value(UUID(),phone1,password1,CONCAT(name1,‘的家长‘));
    END LOOP;
 
 
    CLOSE cur_account;
END $

 

以上是关于mysql-存储过程 使用游标获取数据集并且操作的主要内容,如果未能解决你的问题,请参考以下文章

MySQL存储过程和游标

MySql数据库的存储过程能返回游标么?

MySQL游标使用

MySQL通过游标(CURSOR)实现对select选择集的迭代使用,解决在Navicat中声明游标就一直报错的问题

mysql存储过程 使用游标实现两张表数据同步数据

MySQL游标