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

news/2024/12/21 20:22:02/

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

  • 存储过程和函数

一.存储过程

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.适用场景


http://www.ppmy.cn/news/1537522.html

相关文章

SQL进阶技巧:如何优雅求解指标累计去重问题?

目录 0 需求概述 1 数据准备 2 问题分析 3 小结 0 需求概述 近期公司开发某项学习功能,改功能有很多学习内容(如java,C,python等方向),每天都会有众多学习用户学习某一项或者多项学习内容。产生数据如下表: 产生数据如下表: 日期 内容 学习用户 2022…

Python字符串转JSON格式指南

Python字符串转JSON格式指南 一、需求分析 在数据处理和网络通信中,JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成。本指南旨在介绍如何在Python中将字符串…

小程序项目实践(一)--项目的初始化以及前期的准备工作

目录 1.起步 1.1 uni-app 简介 1.2 开发工具 1.2.1 下载 HBuilderX 1.2.2 安装 HBuilderX 1.2.3 安装 scss/sass 编译 1.2.4 快捷键方案切换 1.2.5 修改编辑器的基本设置 1.3 新建 uni-app 项目 1.4 目录结构 1.5 把项目运行到微信开发者工具 1.6 使用 Git 管理项目 …

Python+Flask接口判断身份证省份、生日、性别、有效性验证+docker部署+Nginx代理运行

这里写目录标题 一、接口样式二、部署流程2.1 镜像打包2.1.1 准备工作2.1.2 build打包2.1.3 dokcer部署运行2.1.4 Nginx代理 三、代码及文件3.1 index.py3.2 areaCodes.json3.3 Dockerfile 一、接口样式 https://blog.henryplus.cn/idcardApi/idCard/query?idcard{idcard} 二、…

LeetCode.611有效三角形的个数

题目链接611. 有效三角形的个数 - 力扣(LeetCode) 1.常规解法(会超时) 由于构成三角形的条件为两边之和大于第三边,就可以遍历该数组,找到所有满足这个条件的三元组,代码如下: pub…

ArkTS基本语法详解

ArkTS基本语法详解: ArkTS页面布局 数据类型 条件判断 数组 ForEach循环遍历 List ListItem组件详解 官方文档 : https://developer.harmonyos.com/cn/develop/arkts/ ArkTS 是 HarmonyOS 优选的主力应用开发语言。 ArkTS 围绕应用开发在 TypeScript &…

Mac 需要杀毒软件?

大部分 mac用户普遍认为 Apple mac 不受病毒和恶意软件的影响。这导致许多 Mac 用户误以为无需为 Mac 安装防病毒软件,但事实并非如此。 在这篇文章中,将深入探讨 Mac 安全性的细节,探索针对 Apple 设备的恶意软件类型,并为您…

Python计算生态概述

Python计算生态涵盖网络爬虫、数据分析、文本处理、数据可视化、图形用户界面、机器学习、Web 开发、网络应用开发、游戏开发、虚拟现实、图形艺术等多个领域,为各个领域的Python使用者提供了极大便利。 网络爬虫是一种按照一定的规则,自动从网络上抓取…