前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL存储过程实例

MySQL存储过程实例

作者头像
程裕强
发布2022-05-06 20:51:52
9880
发布2022-05-06 20:51:52
举报
在这里插入图片描述
在这里插入图片描述

1、简单实例

代码语言:javascript
复制
create procedure demo.p_test1()
begin
  -- 使用 declare语句声明一个变量
  declare id int default 0;
  declare name varchar(50) default '';
  -- 使用set语句给变量赋值
  set id=7521;
  -- 将users表中id=1的名称赋值给username
  select ename into name from demo.emp where empno=id;
  -- 返回变量
  select name;
end;
在这里插入图片描述
在这里插入图片描述

2、通过游标遍历结果集

代码语言:javascript
复制
create table demo.test(
	id int,
	cnt varchar(50)
)
代码语言:javascript
复制
create procedure demo.p_test2()
-- 通过游标遍历结果集
begin
  -- 声明变量
  declare id int default 0;
  declare name varchar(50) default '';
  declare done boolean default 1;
  -- 声明游标
  declare rs cursor for SELECT deptno,dname from demo.dept ;
  -- 定义异常:
  declare continue handler for SQLSTATE '02000' SET done = 0; 
  -- 打开游标
  open rs;
  delete from demo.test;
  while done do 
  	begin
	  fetch rs into id,name;
      INSERT into demo.test SELECT e.deptno,count(1) from demo.emp e WHERE e.deptno =id group by e.deptno;
     end ;
  end while;
  -- 关闭游标
  close rs;
end;
代码语言:javascript
复制
call demo.p_test2();
在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
SELECT * from  demo.test;
在这里插入图片描述
在这里插入图片描述
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-01-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1、简单实例
  • 2、通过游标遍历结果集
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档