CREATE PROCEDURE
1 CREATE PROCEDURE(创建)
CREATEPROCEDURE存储过程名(参数列表) BEGIN SQL语句代码块 END |
注意:
由括号包围的参数列必须总是存在。如果没有参数,也该使用一个空参数列()。每个参数默认都是一个IN参数。要指定为其它参数,可在参数名之前使用关键词OUT或INOUT
在mysql客户端定义存储过程的时候使用delimiter命令来把语句定界符从;变为//。
当使用delimiter命令时,你应该避免使用反斜杠(‘"’)字符,因为那是MySQL的转义字符。
如:
mysql> delimiter // mysql> CREATE PROCEDURE simpleproc (OUT param1INT) ->BEGIN -> SELECTCOUNT(*) INTO param1 FROM t; ->END ->// Query OK, 0 rows affected (0.00 sec) |
1.2 ALTER PROCEDURE(修改)
ALTER PROCEDURE存储过程名SQL语句代码块 |
这个语句可以被用来改变一个存储程序的特征。
1.3 DROP PROCEDURE(删除)
DROP PROCEDURE IF EXISTS存储过程名 eg:DROP PROCEDURE IF EXISTS proc_employee(proc_employee存储过程名) |
这个语句被用来移除一个存储程序。不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程
1.4 SHOW CREATE PROCEDURE(类似于SHOW CREATETABLE,查看一个已存在的存储过程)
SHOW CREATE PROCEDURE存储过程名 |
1.5 SHOW PROCEDURE STATUS(列出所有的存储过程)
SHOW PROCEDURE STATUS |
1.6 CALL语句(存储过程的调用)
CALL存储过程名(参数列表) |
CALL语句调用一个先前用CREATE PROCEDURE创建的程序。
CALL语句可以用声明为OUT或的INOUT参数的参数给它的调用者传回值。
存储过程名称后面必须加括号,哪怕该存储过程没有参数传递
1.7 BEGIN ... END(复合语句)
[begin_label:] BEGIN [statement_list] END [end_label] |
存储子程序可以使用BEGIN ... END复合语句来包含多个语句。
statement_list代表一个或多个语句的列表。statement_list之内每个语句都必须用分号(;)来结尾。
复合语句可以被标记。除非begin_label存在,否则end_label不能被给出,并且如果二者都存在,他们必须是同样的。
1.8 DECLARE语句(用来声明局部变量)
DECLARE语句被用来把不同项目局域到一个子程序:局部变量
DECLARE仅被用在BEGIN ... END复合语句里,并且必须在复合语句的开头,在任何其它语句之前。
1.9 存储程序中的变量
1.1 DECLARE局部变量
DECLARE var_name[,...] type [DEFAULT value] 这个语句被用来声明局部变量。 要给变量提供一个默认值,请包含一个DEFAULT子句。 值可以被指定为一个表达式,不需要为一个常数。 如果没有DEFAULT子句,初始值为NULL。 局部变量的作用范围在它被声明的BEGIN ... END块内。 它可以被用在嵌套的块中,除了那些用相同名字声明变量的块。 |
1.2 变量SET语句
SET var_name = expr [, var_name = expr] 在存储程序中的SET语句是一般SET语句的扩展版本。 被参考变量可能是子程序内声明的变量,或者是全局服务器变量。 在存储程序中的SET语句作为预先存在的SET语法的一部分来实现。这允许SETa=x, b=y, ...这样的扩展语法。 其中不同的变量类型(局域声明变量及全局和集体变量)可以被混合起来。 这也允许把局部变量和一些只对系统变量有意义的选项合并起来。 |
1.3 SELECT ... INTO语句
SELECT col_name[,...] INTO var_name[,...] table_expr 这个SELECT语法把选定的列直接存储到变量。 因此,只有单一的行可以被取回。 SELECT id,data INTO x,y FROM test.t1 LIMIT 1; 注意,用户变量名在MySQL 5.1中是对大小写不敏感的。 |
重要: SQL变量名不能和列名一样。如果SELECT ...INTO这样的SQL语句包含一个对列的参考,并包含一个与列相同名字的局部变量,MySQL当前把参考解释为一个变量的名字。
1.10 MySQL存储过程参数类型(in、out、inout)
此小节内容来自:
参见地址:http://www.blogjava.net/nonels/archive/2009/04/22/233324.html
MySQL存储过程参数(in)
MySQL存储过程 “in”参数:跟 C语言的函数参数的值传递类似, MySQL存储过程内部可能会修改此参数,但对in类型参数的修改,对调用者(caller)来说是不可见的(not visible)。 |
MySQL存储过程参数(out)
MySQL存储过程 “out”参数:从存储过程内部传值给调用者。在存储过程内部,该参数初始值为null,无论调用者是否给存储过程参数设置值 |
MySQL存储过程参数(inout)
MySQL存储过程 inout参数跟 out类似,都可以从存储过程内部传值给调用者。不同的是:调用者还可以通过inout参数传递值给存储过程。 |
总结
如果仅仅想把数据传给 MySQL存储过程,那就使用“in”类型参数;如果仅仅从MySQL存储过程返回值,那就使用“out”类型参数;如果需要把数据传给MySQL存储过程,还要经过一些计算后再传回给我们,此时,要使用“inout”类型参数。 |
1.11 例子:
1.1 创建存储过程
带(输出参数)返回值的存储过程:
--删除存储过程 DROP PROCEDURE IF EXISTS proc_employee_getCount --创建存储过程 CREATE PROCEDURE proc_employee_getCount(out n int) BEGIN SELECT COUNT(*) FROM employee ; END --MYSQL调用存储过程 CALL proc_employee_getCount(@n); |
带输入参数的存储过程:
--删除存储过程 DROP PROCEDURE IF EXISTS proc_employee_findById; --创建存储过程 CREATE PROCEDURE proc_employee_findById(in n int) BEGIN SELECT * FROM employee where id=n; END --定义变量 SET @n=1; --调用存储过程 CALL proc_employee_findById(@n); |
操作存储过程时应注意:
1. 删除存储过程时只需要指定存储过程名即可,不带括号;
2. 创建存储过程时,不管该存储过程有无参数,都需要带括号;
3. 在使用SET定义变量时应遵循SET的语法规则;
SET @变量名=初始值;
4. 在定义存储过程参数列表时,应注意参数名与数据库中字段名区别开来,否则将出现无法预期的结果
CREATE PROCEDURE相关推荐
- MySQL创建存储过程(CREATE PROCEDURE)
MySQL 存储过程是一些 SQL 语句的集合,比如有的时候我们可能需要一大串的 SQL 语句,或者说在编写 SQL 语句的过程中还需要设置一些变量的值,这个时候我们就完全有必要编写一个存储过程.下面 ...
- 2、MySQL创建存储过程(CREATE PROCEDURE)(函数)
MySQL 存储过程是一些 SQL 语句的集合,比如有时候我们可能需要一大串的 SQL 语句,或者说在编写 SQL 语句的过程中需要设置一些变量的值,这个时候我们就完全有必要编写一个存储过程. 编写存 ...
- mysql 存储过程 set into_mysql存储过程之创建(CREATE PROCEDURE)和调用(CALL)及变量创建(DECLARE)和赋值(SET)操作方法...
本文实例讲述了mysql存储过程之创建(CREATE PROCEDURE)和调用(CALL)及变量创建(DECLARE)和赋值(SET)操作方法.分享给大家供大家参考,具体如下: 存储过程创建(CRE ...
- mysql call procedure into_mysql存储过程之创建(CREATE PROCEDURE)和调用(CALL)及变量...
本文实例讲述了mysql存储过程之创建(CREATE PROCEDURE)和调用(CALL)及变量创建(DECLARE)和赋值(SET)操作方法.分享给大家供大家参考,具体如下: 存储过程创建(CRE ...
- sql server累计求和函数_窗口函数 以及 储存过程 create procedure
窗口函数-常见用法,每组内排名 比如,找出每个部门工资前三高的员工等 什么是窗口函数 窗口函数,OLAP函数,online analytical processing,联机分析处理,可以对数据库数据进 ...
- 创建存储过程create procedure
创建存储过程create procedure drop procedure if exists test01; delimiter SETAUTOCOMMIT=0SET AUTOCOMMIT = 0S ...
- MySQL存储过程(CREATE PROCEDURE 存储过程名(参数列表))
MySQL存储过程 #存储过程 /* 含义:一组预先编译好的SQL语句的集合,理解成批处理语句 1.提高代码的重用性 2.简化操作 3.减少了编译次数并且减少了和数据库服务器的连接次数,提高了效率 * ...
- 第十章 SQL命令 CREATE PROCEDURE(一)
文章目录 第十章 SQL命令 CREATE PROCEDURE(一) 大纲 参数 描述 参数 procname parameter_list 第十章 SQL命令 CREATE PROCEDURE(一) ...
- mysql建立存储过程报错_MySQL创建存储过程(CREATE PROCEDURE)
MySQL 存储过程是一些 SQL 语句的集合,比如有时候我们可能需要一大串的 SQL 语句,或者说在编写 SQL 语句的过程中需要设置一些变量的值,这个时候我们就完全有必要编写一个存储过程. 编写存 ...
最新文章
- JS实现禁止浏览器后退返回上一页
- Perl常用语法记录
- java写dnf_【DNF 增幅器 JAVA 模拟增幅代码】
- java 枚举嵌套枚举_java – 如何使用枚举与分组和分组层次/嵌套
- AppUI自动化中的图像识别的使用
- U盘写保护,量产工具修复。
- 大唐杯题库(300道)(一)
- 华硕主板H81M-E BIOS刷NVMe支持M.2固态硬盘成功
- 11.第十二章.采购管理
- 计算机网络ip地址在哪,w7的ip地址在哪?小编教你怎么查看
- jquery 鼠标滚轮实现图片缩放
- URL请求加密 参数的sign签名 与验签
- 启动项中删除微PE工具箱
- Python爬虫:调用百度翻译接口实现中英翻译功能
- 安徽工程大学计算机与信息学院教师,杨丹 - 安徽工程大学 - 计算机与信息学院...
- 详述 MIMIC 数据库 26张数据表(二)之 五种字典表
- android cpu调度6,关于安卓系统的手机CPU频率和I/O调度器的设置,如何设置才能让手机更流畅,求解释。...
- 课程向:深度学习与人类语言处理 ——李宏毅,2020 (P12)
- Linux 内核配置选项
- 阿里云总裁胡晓明:保护客户数据隐私是第一原则
热门文章
- 通过USB在传统电视上播放B站视频
- 大数据背景下的信息资源管理
- 【100%通过率】华为OD机试真题 C++ 实现【农场施肥】【2023 Q1 | 100分】
- 查看windows系统和office是否永久激活(转载)
- webapp期末作业-oneapp
- 小说作者推荐:休屠城合集
- 判断字符串中哪个字符出现的次数最多?
- excel表格拆分多个表如何操作
- 爬虫三(Bs4搜索、Selenium基本使用、无界面浏览器、Selenium自动登录百度案例、自动获取12306登录验证码案例、切换选项卡、浏览器前进后退、登录Cnblogs获取Cookie自动点赞)
- 【vulhub】gitea