MySql存储过程使用游标循环插入数据示例
来源:互联网 发布:金税盘重装后数据没了 编辑:程序博客网 时间:2024/05/16 15:43
本示例通过 while...end while 循环控制游标来实现插入表记录。
DROP PROCEDURE IF exists pro_initCategoryForTradingEntity;
create procedure pro_initCategoryForTradingEntity(tradingEntityId int)
begin
declare f_parent,entityId int;
declare b int default 0; /*是否达到记录的末尾控制变量*/
declare f_name varchar(100);
DECLARE cur_1 CURSOR FOR select FName,FParent,tradingEntityId from t_category_tag;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET b = 1;
OPEN cur_1;
FETCH cur_1 INTO f_name, f_parent, entityId; /*获取第一条记录*/
while b<>1 do
insert into t_category(FName,FParent,FTradingEntity) values(f_name, f_parent, entityId);
FETCH cur_1 INTO f_name, f_parent, entityId; /*取下一条记录*/
end while;
close cur_1;
end;
call pro_initCategoryForTradingEntity(2);
另外循环也可以用repeat...end repeat 来循环控制,以下是我最初所做的示例代码,但结果是插入的实际数据总数多出一条,在此列出作为一个反面示例代码。当然最后用的是上面while...end while 方案。尚优旺
DROP PROCEDURE IF exists pro_initCategoryForTradingEntity;
create procedure pro_initCategoryForTradingEntity(tradingEntityId int)
begin
declare f_parent,entityId,b int;
declare f_name varchar(100);
DECLARE cur_1 CURSOR FOR select FName,FParent,tradingEntityId from t_category_tag;
DECLARE CONTINUE HANDLER FOR NOT FOUND
SET b = 1;
OPEN cur_1;
REPEAT
FETCH cur_1 INTO f_name, f_parent, entityId;
insert into t_category(FName,FParent,FTradingEntity) values(f_name, f_parent, entityId);
UNTIL b = 1
END REPEAT;
close cur_1;
end;
call pro_initCategoryForTradingEntity(2);
- MySql 存储过程使用游标循环插入数据示例
- MySql存储过程使用游标循环插入数据示例
- Mysql存储过程循环内嵌套使用游标示例
- mysql使用存储过程循环插入数据
- MySQL使用存储过程循环插入数据
- mysql使用存储过程循环插入数据
- MySql 存储过程游标使用示例
- mysql存储过程示例(使用嵌套游标)
- mysql存储过程 游标 循环使用介绍
- mysql存储过程 游标 循环使用介绍
- MySQL存储过程 游标循环的使用
- mysql存储过程 游标 循环使用介绍
- MYSQL存储过程循环CURSOR(游标)使用
- mysql 使用存储过程分割字符串利用循环插入数据
- 基于MySQL游标和存储过程的循环插入
- oracle 采用游标循环插入数据的存储过程
- mysql 存储过程示例,有参有返回值,使用到了判断,循环,游标,临时表,事务
- MySQL 存储过程循环插入数据
- MPAndroidchart 教程:图例 Legend(七)
- Two Sum (LeetCode OJ)
- 关于小程序请求接口报400的问题
- Spring学习笔记
- 详解javascript的类
- MySql存储过程使用游标循环插入数据示例
- Runtime梳理
- MPAndroidChart 教程:动态和实时数据 Dynamic & Realtime Data(八)
- 2016ACM/ICPC亚洲区沈阳站-重现赛 部分题解
- MyBatis的foreach语句详解
- linux环境C开发系列0-基础
- MPAndroidChart 教程:修改视窗 Modifying the Viewport(九)
- Android Studio上使用 ButterKnife Zelezny
- 关于vs2013 安装后出现"Cannot find one of more components. Please reinstall the application"处理方法