mysql之存储过程

news/2024/11/28 22:43:11/

目录

1.概念

2.创建语法 

3.调用

4.示例

5.删除

6.查看


1.概念

存储过程和函数类似java中的方法,能够提高代码的重用性,能够简化操作

一组预先编译好的SQL语句的集合,理解成批处理语句,减少了编译次数并且减少了和数据库服务器的连接数,提高了效率。

存储过程可以有0个返回值,也可以有多个返回值。

2.创建语法 

create procedure 存储过程名(参数列表)

begin

存储过程体(一组合法的sql语句)

end

注意:
1、参数列表包含三部分

参数模式 参数名 参数类型  例:
IN stuname VARCHAR(20)

参数模式:

IN: 该参数可以作为输入,也就是该参数需要调用方传入值

OUT: 该参数可以作为输出,也就是该参数可以作为返回值

INOUT: 该参数既可以作为输入又可以作为输出,也就是该参数既需要传入值,又可以返回值。

2、如果存储过程体仅仅只有一句话,BEGIN END可以省略。

存储过程体中的每条SQI语句的结尾要求必须加分号。存储过程的结尾可以使用 DELIMITER 重新设置

语法:
DELIMITER 结束标记案   例:
DELIMITER $

我在Navicat中执行,开始和结束标记可以不加。

3.调用

call 存储过程名(实参列表);

4.示例

创建:

create procedure memo_pro(IN idParam int)
begin

select * from bms_bills_memo
where id =idParam;

end 
调用:

CALL memo_pro(4);

创建:

create procedure memo1_pro(IN idParam int,IN supplierId int)
begin
declare num int default 0;
select count(*) into num from bms_bills_memo
where id =idParam and supplier_id = supplierId;

select if(num >0 ,'存在','不存在');
end 

调用:

call memo1_pro(4,5);

创建:

CREATE PROCEDURE myp (IN beautwName VARCHARC(20) OUT bovName VARCHAR(20) OUT usercpINT )
BEGIN

SELECT boys.boyname ,boys .usercp INTO boyname,usercp
FROM boys
RIGHT JOINbeauty b ON b.boyfriend id = boys .idWHERE b .name=beautyName ;
END 

调用:

call myp('张三',@name,@cp);

select @name,@cp;

5.删除

drop procedure 存储过程名;

6.查看

show create procedure 存储过程名;


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

相关文章

用户画像计算更新

3.1 用户画像计算更新 目标 目标 知道用户画像建立的流程应用 无 3.1.1 为什么要进行用户画像 要做精准推送同样可以使用多种推荐算法,例如:基于用户协同推荐、基于内容协同的推荐等其他的推荐方式,但是以上方式多是基于相似进行推荐。而构…

Exadata存储服务器(又称Exadata存储单元)

存储单元可以说是让Exadata如此大规模普及并且使用效果优异的核心要素。 I/O性能问题始终是Exadata存储或者存储服务器尽力去解决的问题。 Exadata存储服务器概述 Exadata数据库一体机通常预装了3类硬件: 数据库计算节点服务器存储服务器极速的InfiniBand存储交…

【论文翻译】Attention Is All You Need

【论文】Attention is All you Need (neurips.cc) 摘要 主要的序列转换模型是基于复杂的循环或卷积神经网络,其中包括一个编码器和一个解码器。表现最好的模型还通过注意机制连接编码器和解码器。我们提出了一个新的简单的网络架构,Transformer&#xf…

js unicode编码相关

ASCII码 在计算机种中,1 字节对应 8 位二进制数,而每位二进制数有 0、1 两种状态,因此 1 字节可以组合出 256 种状态。如果这 256 中状态每一个都对应一个符号,就能通过 1 字节的数据表示 256 个字符。ASCII就是用于描述英语中的…

Liunx相关服务无法启动,带你一步一步找出问题和解决问题

liunx服务无法开启的原因有各种各样,首先我们需要找到我们究竟是为什么不能能够开启这个服务,这里我们先要去考虑到的一个非常重要的问题就是我们的防火墙有没有启动,防火墙有没有把我们的要开启相关服务的端口给封禁掉。这个是无论如何都要第…

【Unity Shader 赛博小人01】UV准备 SD制作特效贴图

写在前面 Unity 卡通渲染 程序化天空盒提到了——“再整个uv1将云片平铺,将uv1对应到世界坐标x轴旋转角、y轴旋转角,消散信息放到顶点色。”,就是这句话!我又遇到了几个问题(本菜鸡不知道的东西太多太多了&#xff09…

结构型模式-装饰器模式

1.概述 快餐店有炒面、炒饭这些快餐,可以额外附加鸡蛋、火腿、培根这些配菜,当然加配菜需要额外加钱,每个配菜的价钱通常不太一样,那么计算总价就会显得比较麻烦。 使用继承的方式存在的问题: 扩展性不好 如果要再加…

【Leetcode每日一题】35.搜素插入位置|二分查找数组下标

🌱博主简介:大一计科生,努力学习Java中!热爱写博客~预备程序媛 📜所属专栏:LeetCode每日一题–进击大厂 ✈往期博文回顾: 【JavaSE】保姆级教程|1万字10张图学会类与对象–建议收藏 🕵️‍♂️近期目标&…