DBMS-3.4 SQL(4)——存储过程和函数&触发器

本文章的素材与知识来自李国良老师和王珊老师。

存储过程和函数

一.存储过程

1.语法
2.示例

(1)

使用DELIMITER更换终止符后用于编写存储过程语句后,在下次执行SQL语句时记得再使用DELIMITER将终止符再换回分号

使用DELIMITER更换终止符后,存储过程中的BEGIN和END间的SQL语句仍然是使用分号作为终止符

(2)

SELECT ... INTO x ;将查询结果存入变量x中。

二.函数

1.语法

函数的传参方向只能为IN,因此无需像存储过程一样指定。

函数必须指定返回值类型,因此一定要有RETURNS语句。

2.示例

示例中创建函数时缺少了BEGIN和END,得加上。

三.存储过程和函数的删除

四.区别与适用场景

1.区别
(1)参数方向

存储过程的参数方向可以为:IN、OUT、INOUT,因此需要指定参数方向。

函数的参数方向只能为:IN,因此无需指定参数方向。

(2)返回值类型声明

存储过程的返回值是通过OUT或INOUT参数返回的,因此无需通过RETURNS子句声明返回值类型。

函数的返回值是通过RETURN返回的,因此必须通过RETURNS子句声明返回值类型。

(3)返回值个数

存储过程可以通过多个OUT或INOUT参数返回多个值。

函数只能通过RETURN返回指定的某一类型的单值或表对象。

(4)调用

存储过程可以通过CALL语句作为一个独立的部分来执行和调用。

函数只能作为查询语句的一部分来调用,当作值或表来使用。

(5)对数据库的操作

存储过程可以执行更新表的数据库操作。

函数不能执行更新表的数据库操作。

2.适用场景

五.变量和流程控制

1.变量
(1)变量使用范围
(2)变量定义
(3)变量赋值
2.流程控制------IF
(1)语法
(2)示例
3.流程控制------LOOP
(1)语法

使用LOOP语句,最好加上LOOP标签,用于LEAVE后加上要退出的LOOP循环的标签。

(2)示例
4.流程控制------WHILE
(1)语法
(2)示例

触发器

1.语法
(1)创建
(2)删除
(3)示例
2.适用场景
相关推荐
天才测试猿14 分钟前
接口自动化测试难点:数据库验证解决方案
自动化测试·软件测试·数据库·python·测试工具·职场和发展·接口测试
小云数据库服务专线26 分钟前
GaussDB 常用数值类型
数据库·gaussdb
星空下的曙光2 小时前
MySQL → SQL → DDL → 表操作 → 数据类型 知识链整理成一份系统的内容
数据库·sql·mysql
简单的话*2 小时前
如何查看SQL Server的当前端口
数据库·sqlserver
独泪了无痕7 小时前
一文搞懂MyBatis中的TypeHandler
数据库·后端·mybatis
三体世界9 小时前
Mysql基本使用语句(一)
linux·开发语言·数据库·c++·sql·mysql·主键
Giser探索家9 小时前
低空智航平台技术架构深度解析:如何用AI +空域网格破解黑飞与安全管控难题
大数据·服务器·前端·数据库·人工智能·安全·架构
chillxiaohan10 小时前
GO学习记录五——数据库表的增删改查
数据库·学习·golang
一颗星的征途12 小时前
java循环分页查询数据,任何把查询到的数据,分批处理,多线程提交到数据库清洗数据
java·数据库·mysql·spring cloud
NightReader13 小时前
如何解决WordPress数据库表损坏导致的错误
数据库