重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
--传入id,输出name和sex的存储过程,这里同个id有多条数据,所以需要用到游标。
创新互联建站-专业网站定制、快速模板网站建设、高性价比磐安网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式磐安网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖磐安地区。费用合理售后完善,十年实体公司更值得信赖。
DELIMITER //
CREATE PROCEDURE p5(IN v_id INT)
BEGIN
DECLARE nodata INT DEFAULT 0;#注意:这个变量声明必须放在游标声明前面
DECLARE v_name VARCHAR(30);
DECLARE v_sex CHAR(3);
DECLARE c_ns CURSOR FOR SELECT NAME,sex FROM t WHERE id = v_id;
DECLARE EXIT HANDLER FOR NOT FOUND SET nodata = 1;#当读到数据的最后一条时,设置变量为1
OPEN c_ns;
WHILE nodata = 0 DO#判断是不是到了最后一条数据
FETCH c_ns INTO v_name,v_sex;
SELECT v_name,v_sex,nodata;
END WHILE;
CLOSE c_ns;
END
//
--执行该存储过程
mysql call p5(2);
+--------+-------+--------+
| v_name | v_sex | nodata |
+--------+-------+--------+
| song | 女 | 0 |
+--------+-------+--------+
1 row in set (0.04 sec)
+--------+-------+--------+
| v_name | v_sex | nodata |
+--------+-------+--------+
| dan | 男 | 0 |
+--------+-------+--------+
1 row in set (0.05 sec)
Query OK, 0 rows affected, 1 warning (0.05 sec)
--注意:CONTINUE 会继续当前的block 中的语句, 它在set done=1 后继续执行下一个语句。EXIT 则在 set done=1 后离开当前的语句块
所以这里用了EXIT(黄色阴影部分).
如果是continue,结果如下:
mysql call p5(2);
- //
+--------+-------+
| v_name | v_sex |
+--------+-------+
| song | 女 |
+--------+-------+
1 row in set (0.00 sec)
+--------+-------+
| v_name | v_sex |
+--------+-------+
| dan | 男 |
+--------+-------+
1 row in set (0.01 sec)
+--------+-------+
| v_name | v_sex |
+--------+-------+
| dan | 男 |
+--------+-------+
1 row in set (0.02 sec)
Query OK, 0 rows affected, 1 warning (0.03 sec)
恰当的使用IF语句,并在需要跳出循环时,将xxx设置成一个不可满足的条件,那么到下一次循环时,自然不会再执行.
游标一般与循环一起使用,可以设置一个循环结束条件来跳出循环并关闭游标。