mysql数据库存储过程

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

存储过程简介

 

存储过程可以简单理解为一条或者多条sql语句的集合,存储过程用来实现将一组关于表的操作的sql语句当作一个整体来执行,存储过程在实际应用中最主要的特点的事提高执行效率以及sql代码封装功能,特别是sql代码封装功能,如果没有存储过程,在外部程序访问数据库时(例如php),要组织很多sql语句,特别是业务逻辑比较复杂的时候,一大堆的sql和条件夹在php代码中,让人不寒而栗,有了sql存储过程,业务逻辑可以封装存储过程,这样不仅容易维护,而且执行效率也高。

例如:在电子商务站点中使用存储过程来实现商品订单处理

存储过程如何一门程序设计语言,同样包含了数据类型,流程控制,输入和输出和它自己的函数库

创建存储过程

基本语法

Create procedure sp_nane()  函数里面可以有参数也可以没有

Begin

---------  //代码体

End

 

 

Call  sp_nane() 存储过程名  //调用存储过程

 

实例mysql>use mysql

Mysql>Delimiter $$ //定义分隔符

Mysql>Create procedure sp_nane()  函数里面可以有参数也可以没有

Begin

Select user from user;

End$$

Mysql>Delimiter;

 

 

 

查看存储过程

方法一show procedure status

实例:show procedure status \G

 

 

方法二查看系统表information_schema.routines

实例:select * from information_schema.routines\G

 

方法三通过show crerate procedure语句查看存储过程定义信息

实例:show crerate procedure proce_user\G

删除存储过程

Drop procedure 存储过程名字  删的时候不要加().

实例:drop procedure proce_param_inout;

流程控制核心中核心

 

顺序

分支

循环

循环控制

WHILE ---DO--END WHILE  //先判断再执行

实例:

Mysql>Delimiter $$ //定义分隔符

Mysql>create table t1(id int);

Mysql>Create procedure proce_while()  函数里面可以有参数也可以没有

Begin

Declare i int;  //定义变量

Set i=1;  //将变量做了一个初始化,如果不做初始化,将为null

While i<5 do

Insert into t1 values(i);

Set i=i+1;

End while;

End$$

Mysql>Delimiter;

 

 

Pepeat---until end pepeat  先执行再判断

实例:

Mysql>Delimiter $$ //定义分隔符

Mysql>Create procedure proce_repeat()  函数里面可以有参数也可以没有

Begin

Declare i int default 1;  //定义变量,初始化

repeat  

Insert into t1 values(i);

Set i=i+1;

Until i>=6

End repeat;

End$$

Mysql>Delimiter;

 

Loop--end loop

实例:

Mysql>Delimiter $$ //定义分隔符

Mysql>Create procedure proce_loop()  函数里面可以有参数也可以没有

Begin

Declare i int default 1;  //定义变量,初始化

Loop_label:loop   //定义一个标号,跟标签一样

Insert into t1 values(i);

Set i=i+1;

If  i>=6 then

Leave loop_label;  

End if;

End loop;

End$$

Mysql>Delimiter;

 

输入输出类型

1)In  往存储过程里面传参,存储过程内部会改变数值,调用者是不会看到的

实例:

Mysql>Delimiter $$ //定义分隔符

Mysql>Create procedure proce_param_in(in id int) //in传值传的是id字段,int类型的

Begin

If (id is null) then  //如果id变量是空值

Select id is null  as id_null;  

Else

Set i=i+1;

End if;

Select id as id_inside; //打印一下id的值

End$$

Mysql>Delimiter;

 

 

 

2)Out存储过程内部传值给调用者,不接受外部传值的

实例:

Mysql>Delimiter $$ //定义分隔符

Mysql>Create procedure proce_param_out(out id int) //out传值传的是id字段,int类型的

Begin

Select id  as id_inside_1;  //id初始值为null

If (id is not null) then  //如果id变量不是空值

Set id=id+1;

Select id as id_inside_2; //打印一下id的值

Else

Select 100 into id;  //100输入到id

End if;

Select id as id_inside_3;

End$$

Mysql>Delimiter;

 

3)inout 可以接受调用者的传值,而且还会把最后改变的结果返回给调用者

实例:

Mysql>Delimiter $$ //定义分隔符

Mysql>Create procedure proce_param_inout(inout id int) //out传值传的是id字段,int类型的

Begin

Select id  as id_inside_1;  //id值为调用者传进来的值

If (id is not null) then  //如果id变量不是空值

Set id=id+1;

Select id as id_inside_2; //打印一下id的值

Else

Select 100 into id;  //100输入到id

End if;

Select id as id_inside_3;

End$$

Mysql>Delimiter;

本文转自    探花无情   51CTO博客,原文链接:http://blog.51cto.com/983865387/1917422


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
存储 SQL 关系型数据库
【MySQL 数据库】9、存储过程
【MySQL 数据库】9、存储过程
204 0
|
8月前
|
存储 SQL NoSQL
数据库存储过程和函数(二)
数据库存储过程和函数
85 0
|
8月前
|
存储 SQL 缓存
数据库存储过程和函数(一)
数据库存储过程和函数
72 0
|
7月前
|
存储 SQL Oracle
数据库中存储过程和触发器有什么区别?
数据库中存储过程和触发器有什么区别?
104 0
|
8月前
|
存储 SQL 关系型数据库
数据库存储过程创建可能出现的问题
数据库存储过程创建可能出现的问题
137 0
|
9月前
|
存储 数据库
数据库 存储过程
数据库 存储过程
|
11月前
|
存储 SQL 关系型数据库
MySQL数据库————存储过程和函数(一)
MySQL数据库————存储过程和函数(一)
469 0
|
11月前
|
存储 SQL 关系型数据库
MySQL数据库————存储过程和函数(二)
MySQL数据库————存储过程和函数(二)
142 0
|
存储 SQL 数据处理
数据库(6)--存储过程
数据库(6)--存储过程
168 0
数据库(6)--存储过程
|
存储 SQL 数据库
SQL数据库编写存储过程
SQL数据库编写存储过程