mysql游标遍历循环 插入数据

本文通过一个实例解释了如何使用MySQL游标遍历循环插入数据。通过创建存储过程,遍历查询结果,将特定记录复制到每个学生,实现数据的批量复制。涉及的关键点包括游标声明、变量使用以及异常处理。
摘要由CSDN通过智能技术生成
BEGIN
 DECLARE  no_more_record INT DEFAULT 0;
 DECLARE  insertColumn VARCHAR(18);
 DECLARE  cur_record CURSOR FOR   SELECT insertParam FROM testTable;  
 DECLARE  CONTINUE HANDLER FOR NOT FOUND  SET  no_more_record = 1; 
 OPEN  cur_record; 
 FETCH  cur_record INTO insertColumn; 
  WHILE no_more_record != 1 DO
  IF NOT  EXISTS(SELECT column1 FROM insertTable WHERE column1=insertColumn) THEN 
  INSERT  INTO  insertTable 
  SELECT insertColumn,colunm2,column3,colunm4 WHERE column1='123';
END IF;
 FETCH  cur_record INTO insertColumn;
 END WHILE;
 CLOSE  cur_record;
END

以上代码实现的功能:为testTable字段每个insertParam添加insertTable中column1=‘123’对应的所有记录。

如果这句话比较难懂的话,可以想象以下情景:

一个班级(学生表)有小明,小刚,小红三名同学,

小明同学有苹果,橘子,梨(学生-资源表)。

现在要求所有学生都有这三种水果,也就是遍历学生表,再把小明拥有的资源复制给每个学生一份。最后学生-资源表中所有学生都对应三个水果。

MySQL 支持使用游标进行数据操作,可以使用嵌套循环实现对多个表的操作。下面是一个示例代码,演示如何使用游标嵌套循环实现对两个表的操作。 假设有两个表 A 和 B,其中 A 表包含字段 id 和 name,B 表包含字段 id 和 value,现在需要将两个表中相同 id 的记录拼接在一起,得到一个新的表 C,包含字段 id、name 和 value。 ``` DECLARE cur_a CURSOR FOR SELECT id, name FROM A; DECLARE cur_b CURSOR FOR SELECT id, value FROM B; DECLARE done INT DEFAULT FALSE; DECLARE a_id INT; DECLARE a_name TEXT; DECLARE b_id INT; DECLARE b_value TEXT; CREATE TABLE C ( id INT PRIMARY KEY, name TEXT, value TEXT ); OPEN cur_a; FETCH cur_a INTO a_id, a_name; WHILE NOT done DO IF a_id IS NOT NULL THEN OPEN cur_b; FETCH cur_b INTO b_id, b_value; WHILE NOT done DO IF b_id IS NOT NULL THEN IF a_id = b_id THEN INSERT INTO C (id, name, value) VALUES (a_id, a_name, b_value); END IF; ELSE SET done = TRUE; END IF; FETCH cur_b INTO b_id, b_value; END WHILE; CLOSE cur_b; END IF; FETCH cur_a INTO a_id, a_name; END WHILE; CLOSE cur_a; ``` 这段代码中,首先定义了两个游标,分别对应表 A 和表 B。然后使用两个循环,分别遍历表 A 和表 B 中的记录。在表 A 的循环中,对于每一条记录,都打开游标 cur_b,然后在表 B 中查找相同 id 的记录,并将它们插入到表 C 中。当表 B 的游标遍历完所有记录后,关闭游标 cur_b,继续遍历表 A 的下一条记录。最后关闭游标 cur_a,完成操作。 需要注意的是,游标嵌套循环可能会导致性能问题,特别是在处理大量数据时。因此,在实际应用中,应该尽量避免使用游标嵌套循环,而是使用其他方式进行数据操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值