当前位置: 首页 > news >正文

存储过程及练习

 1.存储过程

📖什么是存储过程?

存储过程和函数是事先经过编译并存储在数据库中的一段sql语句集合,调用存储过程函数可以简

化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的

效率是有好处的。

存储过程和函数的区别:

1. 函数必须有返回值,而存储过程没有。

2. 存储过程的参数可以是IN、OUT、INOUT类型,函数的参数只能是IN

📘优点

存储过程只在创建时进行编译;而SQL语句每执行一次就编译一次,所以使用存储过程可以

提高数据库执行速度

简化复杂操作,结合事务一起封装

复用性好

安全性高,可指定存储过程的使用权

注意:并发量少的情况下,很少使用存储过程。并发量高的情况下,为了提高效率,用存储过程

比较多

存储过程练习 

1、创建一个存储过程avg_sal_a,有2个参数,分别是部门名称dept_name及接收平均工资其中部门名称测试参数为上海中心,接收平均薪资变量为@a。

mysql> select avg(salary) from employee where department_NO in (select number from department where name = "上海中心");--查询sql
+-------------+
| avg(salary) |
+-------------+
| 2800.000000 |
+-------------+
1 row in set (0.00 sec)
​
mysql> \d $--改结束符
--创建存储过程
mysql> create procedure avg_sal_a(in dept_name varchar(255),out avg_dept int)-> begin-> select avg(salary) into avg_dept from employee where department_NO in (select number from department where name = dept_name);-> end$
Query OK, 0 rows affected (0.00 sec)
​
mysql> \d ;--改回结束符
mysql> call avg_sal_a("上海中心",@a);--使用存储过程
Query OK, 1 row affected (0.00 sec)
​
mysql> select @a;--查看参数
+------+
| @a   |
+------+
| 2800 |
+------+
1 row in set (0.00 sec)

2.创建存储过程,给定参数员工姓名,查询该员工名所在部门的最高薪资,并返回给变量@a;

mysql> select max(salary) from employee group by department_NO having department_NO = (select  department_NO from employee where name =
"吴所为");--查询语句
+-------------+
| max(salary) |
+-------------+
|     2800.00 |
+-------------+
1 row in set (0.00 sec)
mysql> \d $--改结束符
--创建存储过程
mysql> create procedure max_sal_e(in e_name varchar(255),out max_sal int)-> begin-> select max(salary) into max_sal from employee group by department_NO having department_NO = (select  department_NO from employee where name = e_name);-> end&
Query OK, 0 rows affected (0.00 sec)
mysql> \d ;--改回结束符
mysql> call max_sal_e("吴所为",@a);--使用存储过程
Query OK, 1 row affected (0.00 sec)
​
mysql> select @a;--查看
+------+
| @a   |
+------+
| 2800 |
+------+
1 row in set (0.00 sec)
​

http://www.lryc.cn/news/484959.html

相关文章:

  • 【在Linux世界中追寻伟大的One Piece】多路转接epoll
  • 设计模式-参考的雷丰阳老师直播课
  • Python +Pyqt5 简单视频爬取学习(一)
  • Python Requests模块全面教程
  • PyQt入门指南六十 与Python其他库的集成方法
  • Android15之解决:Dex checksum does not match for dex:framework.jar问题(二百三十九)
  • 车企自动驾驶功能策略 --- 硬件预埋(卷传感器配置)
  • 【已为网站上传证书,却显示不安全】
  • docker busybox作为initContainers
  • 20.UE5UI预构造,开始菜单
  • Electron教程1-初学入门
  • 从北美火到中国,大数据洞察品牌“STANLEY”的突围之路
  • 深度学习之GAN应用
  • 鸿蒙生态下的安全隐私保护:打造用户信任的应用体验
  • 用pandoc工具实现ipynb,md,word,pdf之间的转化
  • 第三十一天|贪心算法| 56. 合并区间,738.单调递增的数字 , 968.监控二叉树
  • 力扣 最长公共前缀-14
  • IDEA调整警告级别【IntelliJ IDEA 2024.2.0.1】
  • Vulnhub靶场 Billu_b0x 练习
  • Essential Cell Biology--Fifth Edition--Chapter one (6)
  • Jupyter Book 快捷键总结大全
  • Spring Authorization Server OAuth2.1
  • 解决”重复文件名重命名“问题【根据Word系统方式】
  • 【PyTorch】PyTorch Geometric(PyG)安装指南:如何高效配置图神经网络环境
  • SolidWorks21装配体中一个零件无法改为线架图
  • 11.11机器学习_介绍和定义
  • 【代码审计】常见漏洞专项审计-业务逻辑漏洞审计
  • SpringBoot单体服务无感更新启动,动态检测端口号并动态更新
  • CSS基础知识04
  • python程序对服务器cpu和内存资源占用的管理。