Mysql存储过程基本语法

Mysql存储过程基本语法Mysql存储过程基本语法转载自这篇文章delimiter//一般情况下MYSQL以;结尾表示确认输入并执行语句,但在存储过程中;不是表示结束,因此可以用该命令将;号改为//表示确认输入并执行。一.创建存储过程1.基本语法:createproceduresp_name()begin………end2.参数传递二.调用存储过程1.基本语法:ca…

大家好,又见面了,我是你们的朋友全栈君。

Mysql 存储过程基本语法

转载自这篇文章

delimiter //
一般情况下MYSQL以;结尾表示确认输入并执行语句,但在存储过程中;不是表示结束,因此可以用该命令将;号改为//表示确认输入并执行。

一.创建存储过程

1.基本语法:

create procedure sp_name()
begin
………
end

2.参数传递

二.调用存储过程

1.基本语法:call sp_name()
注意:存储过程名称后面必须加括号,哪怕该存储过程没有参数传递

三.删除存储过程

1.基本语法:
drop procedure sp_name//
2.注意事项
(1)不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程

四.区块,条件,循环

1.区块定义,常用
begin
……
end;
也可以给区块起别名,如:
lable:begin
………..
end lable;
可以用leave lable;跳出区块,执行区块以后的代码
2.条件语句

Mysql存储过程基本语法if 条件 then
Mysql存储过程基本语法 statement
Mysql存储过程基本语法 else
Mysql存储过程基本语法 statement
Mysql存储过程基本语法 end if;

3.循环语句
(1).while循环

Mysql存储过程基本语法[label:] WHILE expression DO
Mysql存储过程基本语法
Mysql存储过程基本语法 statements
Mysql存储过程基本语法
Mysql存储过程基本语法 END WHILE [label] ;
Mysql存储过程基本语法

 

(2).loop循环

Mysql存储过程基本语法[label:] LOOP
Mysql存储过程基本语法
Mysql存储过程基本语法 statements
Mysql存储过程基本语法
Mysql存储过程基本语法 END LOOP [label];

(3).repeat until循环

Mysql存储过程基本语法[label:] REPEAT
Mysql存储过程基本语法
Mysql存储过程基本语法 statements
Mysql存储过程基本语法
Mysql存储过程基本语法 UNTIL expression
Mysql存储过程基本语法
Mysql存储过程基本语法 END REPEAT [label] ;

五.其他常用命令

1.show procedure status
显示数据库中所有存储的存储过程基本信息,包括所属数据库,存储过程名称,创建时间等
2.show create procedure sp_name
显示某一个存储过程的详细信息

下面看一个例子

一、MySQL 创建存储过程

“pr_add” 是个简单的 MySQL 存储过程,这个MySQL 存储过程有两个 int 类型的输入参数 “a”、“b”,返回这两个参数的和

delimiter //   — 改变分割符

drop procedure if exists pr_add//  — 若之前创建有这个存储过程则删除

计算两个数之和

  1. create procedure pr_add (a int,b int)
  2. begin
  3. declare c int;
  4. if a is null then
  5. set a = 0;
  6. end if;
  7. if b is null then
  8. set b = 0;
  9. end if;
  10. set c = a + b;
  11. select c as sum;
  12. end
  13. //

二、调用 MySQL 存储过程

  1. call pr_add(10, 20);

执行 MySQL 存储过程,存储过程参数为 MySQL 用户变量。

  1. set @a = 10;
  2. set @b = 20;
  3. call pr_add(@a, @b);

三、MySQL 存储过程特点

创建 MySQL 存储过程的简单语法为:

  1. create procedure 存储过程名字()
  2. (
  3. [in|out|inout] 参数 datatype
  4. )
  5. begin
  6. MySQL 语句;
  7. end;

MySQL 存储过程参数如果不显式指定“in”、“out”、“inout”,则默认为“in”。习惯上,对于是“in” 的参数,我们都不会显式指定。

1. MySQL 存储过程名字后面的“()”是必须的,即使没有一个参数,也需要“()”

2. MySQL 存储过程参数,不能在参数名称前加“@”,如:“@a int”。下面的创建存储过程语法在 MySQL 中是错误的(在 SQL Server 中是正确的)。 MySQL 存储过程中的变量,不需要在变量名字前加“@”,虽然 MySQL 客户端用户变量要加个“@”。

  1. create procedure pr_add
  2. (
  3. @a int, — 错误
  4. b int — 正确
  5. )

3. MySQL 存储过程的参数不能指定默认值。

4. MySQL 存储过程不需要在 procedure body 前面加 “as”。而 SQL Server 存储过程必须加 “as” 关键字。

  1. create procedure pr_add
  2. (
  3. a int,
  4. b int
  5. )
  6. as — 错误,MySQL 不需要 “as”
  7. begin
  8. mysql statement …;
  9. end;

5. 如果 MySQL 存储过程中包含多条 MySQL 语句,则需要 begin end 关键字。

  1. create procedure pr_add
  2. (
  3. a int,
  4. b int
  5. )
  6. begin
  7. mysql statement 1 …;
  8. mysql statement 2 …;
  9. end;

6. MySQL 存储过程中的每条语句的末尾,都要加上分号 “;”

  1. declare c int;
  2. if a is null then
  3. set a = 0;
  4. end if;
  5. end;

7. MySQL 存储过程中的注释。

  1. declare c int; — 这是单行 MySQL 注释 (注意 — 后至少要有一个空格)
  2. if a is null then # 这也是个单行 MySQL 注释
  3. set a = 0;
  4. end if;
  5. end;

8. 不能在 MySQL 存储过程中使用 “return” 关键字。

  1. set c = a + b;
  2. select c as sum;
  3. end;

9. 调用 MySQL 存储过程时候,需要在过程名字后面加“()”,即使没有一个参数,也需要“()”

  1. call pr_no_param();

10. 因为 MySQL 存储过程参数没有默认值,所以在调用 MySQL 存储过程时候,不能省略参数。可以用 null 来替代。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/160812.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • c语言中char类型转int类型「建议收藏」

    c语言中char类型转int类型「建议收藏」前言在九度oj做acm的时候,经常会遇到了char类型和int类型相互转化的问题,这里进行一下总结。今后,可能会多次更新博客,因为半年做了很多总结,但是都是保存在word文档上了,现在开始慢慢向CSDN博客转移。问题类型char型数字转换为int型转换方法a[i]-‘0’参考程序#include#include#includei

    2022年10月2日
    3
  • navicat生成激活码错误-激活码分享

    (navicat生成激活码错误)最近有小伙伴私信我,问我这边有没有免费的intellijIdea的激活码,然后我将全栈君台教程分享给他了。激活成功之后他一直表示感谢,哈哈~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.htmlS3…

    2022年3月26日
    69
  • matlab 查看函数,如何查看MATLAB函数的源代码 | 学步园「建议收藏」

    matlab 查看函数,如何查看MATLAB函数的源代码 | 学步园「建议收藏」如何查看MATLAB函数的源代码大家都知道MATLAB是开源的,所有的函数源代码都是可以查看的。但是,对于初学者来说,可能还不知道如何查看MATLAB函数的源代码。函数之  type假设需要查看function_name的源代码,在命令窗口中键入 type  function_name即:>>typeimreadfunction[X,map,alpha]=imread(v…

    2025年11月11日
    4
  • matlab三维拟合曲面_热传导的三种边界条件

    matlab三维拟合曲面_热传导的三种边界条件1第三类边界条件的热传导方程1.1热传导方程热传导在一维的各向同性介质里的传播可用以下方程表达:∂u∂t=a∂2u∂x2(1)\frac{\partialu}{\partialt}=a\frac{\partial^{2}u}{\partialx^{2}}\tag{1}∂t∂u​=a∂x2∂2u​(1)其中,u=u(x,t)u=u(x,t)u=u(x,t),a=λcρa=\frac{\lambda}{c\rho}a=cρλ​,λ\lambdaλ表示介质的热传导率,ccc表

    2025年7月31日
    6
  • js中的闭包[通俗易懂]

    js中的闭包[通俗易懂]闭包是js的一个难点也是它的一个特色,是我们必须掌握的js高级特性,那么什么是闭包呢?它又有什么用呢?我们都知道,js的作用域分两种,全局和局部,基于我们所熟悉的作用域链相关知识,我们知道在js作用域环境中访问变量的权利是由内向外的,内部作用域可以获得当前作用域下的变量并且可以获得当前包含当前作用域的外层作用域下的变量,反之则不能,也就是说在外层作用域下无法获取内层作用域下的变量,同样在不同的函…

    2022年6月25日
    28
  • file指定路径_目标实现的策略与路径

    file指定路径_目标实现的策略与路径FileProvider路径配置策略的理解★FileProvider的使用在AndroidManifest.xml中<providerandroid:name="android.support.v4.content.FileProvider"android:authorities="set_your……

    2025年7月30日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号