存储过程和存储函数

news2024/9/22 23:31:43

存储过程没有返回值,存储函数有返回值

存储过程

存储过程的参数类型有这几种:

  1. 没有参数(无参数无返回值)
  2. in(有参数无返回值)
  3. out(无参数有返回值)跟着——在查询语句后面加上into看下面的例子
  4. 即带in又带out(有参数有返回值)
  5. inout(有参数有返回值)

语法形式

sqlCREATE PROCEDURE 存储过程名(IN|OUT|INOUT 参数名 参数类型)
[characteristics……]
BEGIN 
	存储过程体
END

复制

在执行上面代码的时候,因为存储过程体中的sql语句有;而执行到;就结束了,但是我们还没有到我们存储过程的结束。所有我们要设置结束标志

设置结束标志: DELIMITER 新的结束标志 那么上面的代码可以这样写

sqlDELIMITER $
CREATE PROCEDURE 存储过程名(IN|OUT|INOUT 参数名 参数类型)
[characteristics……]
BEGIN 
	存储过程体
END $
DELIMITER ;#从新把原来的;恢复

复制

例:OUT

sqlDELIMITER //

CREATE PROCEDURE show_min_salary(OUT ms DOUBLE)
BEGIN
	SELECT MIN(salary) INTO ms
	FROM employees;
END //

DELIMITER ;

复制

characteristics表示创建存储过程时对存储过程的约束条件 约束条件如下:

例:

sqlDELIMITER $
CREATE PROCEDURE select_min_salary()

BEGIN
	SELECT MIN(salary)
	FROM emp;
END $

DELIMITER ;

复制

调用——CALL select_min_salary(); CALL 存储过程

传入参数的时候可以自己定义参数,怎么设置参数,后面一节会讲解,暂时这样设置SET @变量名

存储函数

创建存储函数与创建存储过程差不多 语法形式:

sqlCREATE FUNCTION 函数名(参数名 参数类型)
RETURNS 返回类型
约束条件
BEGIN
	函数体
END

复制

调用存储函数 SELECT 函数名(实参列表)

查看

查看创建信息: SHOW CREATE {PROCEDURE | FUNCTION} 存储过程名或函数名

查看状态信息: SHOW {PROCEDURE | FUNCTION} STATUS ——这样会查看所有的 我们可以用模糊查询 SHOW {PROCEDURE | FUNCTION} STATUS LIKE '名字'

也可以从information_schema.Routines表 中查看

sqlSELECT * FROM information_schema.Routines
WHERE ROUTINE_NAME='存储过程或函数的名' [AND ROUTINE_TYPE = {'PROCEDURE|FUNCTION'}];

复制

不写写了,直接截图:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/708207.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

“ReferenceError: Dialog is not defined“

“ReferenceError: Dialog is not defined” 解决办法:变成this.$dialog 引入 Dialog 组件后,会自动在 Vue 的 prototype 上挂载 $dialog 方法,在所有组件内部都可以直接调用此方法。

【Java EE】-博客系统一(前后端分离)

作者:学Java的冬瓜 博客主页:☀冬瓜的主页🌙 专栏:【JavaEE】 分享: 谜一样的 沉默着的 故事你真的在听吗 ——《平凡之路》 主要内容:准备工作:创建maven,引入依赖。设计数据库并编写数据库代码…

“去高精地图”跟“轻高精地图”有啥区别?落地的挑战又是啥? | 九章自动驾驶随笔之一...

交流群 | 进“传感器群/滑板底盘群/汽车基础软件群/域控制器群”请扫描文末二维码,添加九章小助手,务必备注交流群名称 真实姓名 公司 职位(不备注无法通过好友验证) 编辑 | 苏清涛 真正影响Mapless技术路线落地的最大难点在于…

C语言中的switch语句基本用法

导语:switch语句是一个多分支选择语句,并且可以支持嵌套 switch语句的基本格式 switch语句通过将表达式的值与常量值进行比对,如果相等则执行后面的语句,如果不相等则跳到下一个case语句,当表达式和常量值相等&#x…

探索Python条件语句的奇妙世界:解密逻辑与控制流

文章目录 前言if 语句if ... else ...多重判断(if ... elif ... else...)if 嵌套猜数字游戏三目运算符 前言 Python的条件语句用来根据特定的条件决定程序的执行流程。它允许程序根据条件的真假执行不同的代码块,从而实现不同情况下的不同操…

Linux系统Centos7 安装Tomcat详细步骤

必须安装过jdk (1)下载linux版本的tomcat🍉 https://tomcat.apache.org/download-90.cgi (2) 把tomcat软件放到linux中🍉 (3)解压🍉 (4)防火墙放行tomcat端口🍉 firewall-cmd -…

Verilog基础之十二、分频器实现

目录 一、前言 二、工程设计 2.1 工程代码 2.2 测试文件代码 2.3 综合结果 2.4 仿真结果 一、前言 分频器即将高频率的信号转化为更低频率的信号,常用的分频可使用锁相环PLL来实现,也可自己编写RTL代码来实现。根据分频的系数N(假设信号频率为M&am…

linux环境下重置mysql密码

一、my.cnf 首先,需要找到my.cnf这个文件。 Linux 操作系统中 MySQL 的配置文件是 my.cnf,一般会放在 /etc/my.cnf 或 /etc/mysql/my.cnf 目录下。总的来说,my.cnf 类似于 my.ini 配置文件。 如果实在找不到,使用命令&#xff…

C++ 信号处理

信号是由操作系统传给进程的中断,会提早终止一个程序。在 UNIX、LINUX、Mac OS X 或 Windows 系统上,可以通过按 CtrlC 产生中断。 有些信号不能被程序捕获,但是下表所列信号可以在程序中捕获,并可以基于信号采取适当的动作。这些…

组合预测模型 | Matlab基于时间卷积神经网络结合门控循环单元的(TCN-GRU)的回归预测预测,多变量输入模型

文章目录 效果一览文章概述部分源码参考资料效果一览 文章概述 基于时间卷积神经网络结合门控循环单元的(TCN-GRU)的回归预测预测,多变量输入模型(Matlab完整源码和数据) 基于时间卷积神经网络结合门控循环单元的(TCN-GRU)的回归预测预测,多变量输入模型(Matlab完整源码和数…

Vite 项目性能分析与优化

性能优化一直是前端工程化中老生常谈的话题,也是前端项目优化的重要的优化点。事实上,随着项目越来越庞大,稍不注意就会产生明显的性能问题。在不同的场景中,我们对于项目性能的关注点是不一样的。在项目开发阶段,我们…

English Learning - L3 作业打卡 Lesson7 Day55 2023.6.30 周五

English Learning - L3 作业打卡 Lesson7 Day55 2023.6.30 周五 引言🍉句1: I could feel the wind against my face and the beat of my racing heart as if it were happening in that very moment.成分划分弱读连读爆破语调 🍉句2: And that is when …

力扣 236. 二叉树的最近公共祖先

题目来源:https://leetcode.cn/problems/lowest-common-ancestor-of-a-binary-tree/description/ C题解:弄清思路就好写,理不清思路就唉。。 递归法: 1. 确定函数返回类型和参数:目标是最近公共节点,所以…

debian linux安装配置企业私有网盘

一、适用环境 1、中小型企业的某些部门之间经常要进行数据的交换与共享时,则可使用企业内部专业的服务器,把剩余的硬盘存储容量配置成为共享网盘的形式,供部门之间进行数据交换。 2、可将多个硬盘通过debian Linux系统组成软阵列的1个逻辑盘…

Scrapy框架之MongoDB聚合操作

目录 MongoDB聚合操作 聚合操作的基本语法 常用的聚合操作 管道命令之$group 按照某个字段进行分组 详解 计算集合中某个字段的平均值 常用表达式 管道命令之$match 示例 管道命令之$sort 管道命令之$skip 和 $limit 管道命令之$project MongoDB聚合操作 在…

ts:Set、Map

观看小满老师课程的随笔~ 前言 与 原生 js 中的原理和方法是相同的,这里只是用了 ts 中的 强类型 一、Set 天然去重,引用类型除外增删改查:add、has、delete、clear循环:forEach、entries、keys、for...of(内置的有iterator迭代…

CCF-CSP真题《202305-2 矩阵运算》思路+python,c++满分题解

想查看其他题的真题及题解的同学可以前往查看:CCF-CSP真题附题解大全 试题编号:202305-2试题名称:矩阵运算时间限制:5.0s内存限制:512.0MB问题描述: 题目背景 Softmax(QKTd)V 是 Transformer 中注意力模块的…

javac命令编译.java源文件报错“编码GBK的不可映射字符“

原因在于.java源文件编码方式是UTF-8 二cmd DOS窗口编码格式是GBK 解决办法 javac -encoding UTF-8 *.java

Kettle 实现动态表查询

文章目录 前言动态表名查询数据 :一、获取表名1、新建一个转换getTableName,拖入获取系统信息,字段选择,设置变量2、打开 获取系统信息 编辑界面,填写名称,点击类型选择要获取的信息类型3、打开字段选择,选…