mysql-游标使用

mysql存储过程好几年没用了,最近看文档,就写了个小例子实践下,增强记忆。
例子主要实现的是从一张表更新记录到另外一张表去。

CREATE TABLE `user_info` (
`user_id` int(11) default NULL,
`user_name` varchar(20) default NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8


CREATE TABLE `tmp_user` (
`tmp_user_id` int(11) default NULL,
`tmp_name` varchar(20) default NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8


insert into `user_info` (`user_id`, `user_name`) values('20','aa');
insert into `user_info` (`user_id`, `user_name`) values('21','bb');
insert into `user_info` (`user_id`, `user_name`) values('22','cc');
insert into `user_info` (`user_id`, `user_name`) values('23','dd');

insert into `tmp_user` (`tmp_user_id`, `tmp_name`) values('20','');
insert into `tmp_user` (`tmp_user_id`, `tmp_name`) values('22','');
insert into `tmp_user` (`tmp_user_id`, `tmp_name`) values('23','');

下面创建存储过程

DELIMITER $$

DROP PROCEDURE IF EXISTS `test`.`pro_user`$$

CREATE DEFINER=`root`@`localhost` PROCEDURE `pro_user`()
BEGIN
DECLARE total INT DEFAULT 0;
DECLARE tmpCount INT DEFAULT 0;
DECLARE userId INT DEFAULT 0;
DECLARE userName varchar(50);

DECLARE cur1 CURSOR FOR SELECT user_id,user_name FROM user_info;
SELECT count(*) INTO total FROM user_info;

OPEN cur1;
REPEAT
FETCH cur1 INTO userId, userName;
SET tmpCount = tmpCount + 1;
UPDATE tmp_user set tmp_name=userName where tmp_user_id=userId;
UNTIL tmpCount >=total END REPEAT;

CLOSE cur1;
select total ;

END$$
DELIMITER ;


调用CALL pro_user();
查看tmp_user,发现记录已经同步过去了。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值