存储mysql数据库的详细过程
admin
2023-05-25 19:21:40
0

下面一起来了解下存储mysql数据库的详细过程,相信大家看完肯定会受益匪浅,文字在精不在多,希望存储mysql数据库的详细过程这篇短内容是你想要的。

存储过程简介

存储过程可以简单理解为一条或者多条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;

 存储mysql数据库的详细过程

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;

 看完存储mysql数据库的详细过程这篇文章后,很多读者朋友肯定会想要了解更多的相关内容,如需获取更多的行业信息,可以关注我们的行业资讯栏目。

相关内容

热门资讯

卓世科技荣膺「2026 福布斯... 2026-05-20 10:51:42 作者:狼叫兽 近日,全球权威商业媒体《福布斯》正式发布「...
韩国海军提交核潜艇请示报告,正... 澎湃新闻记者 朱郑勇 实习生 王镱家韩国海军已经向韩国联合参谋本部提交了关于建造核动力潜艇的请示报告...
星元晶算携手清华大学,共筑人形... 深圳和天津2026年5月19日-- 2026年5月19日,星元晶算科技(深圳)有限公司与清华大学天津...
毫米波电缆组件厂家梳理 军工与... 导语:毫米波电缆组件作为高频信号传输的核心部件,在雷达、卫星通信、5G基站等场景中需求持续增长。根据...
618大内存折叠屏手机怎么选?... 随着618购物节临近,不少用户开始考虑升级手中的设备,尤其是对存储空间和性能有更高要求的高端用户。在...
进口不锈钢氢气减压阀十大行业标... 进口不锈钢氢气减压阀最新十大品牌是由多个全球知名权威机构和媒体会定期发布阀门行业相关排名榜单,本排行...
原创 投... 当李彦宏在2026年百度 Create 开发者大会上提出“DAA(日活智能体数)将成为 AI 时代新...
市场监管总局开展居民水电气计量... 记者今天了解到,为持续规范供水供电供气市场秩序,切实维护人民群众切身利益,市场监管总局部署开展居民水...
坚定不移沿着习近平总书记指引的... 5月14日,工人在洛轴集团智能工厂生产线上作业。5月13日,由中信重工牵头研制的国家重点研发计划“移...
2026年郑州市区中招政策发布... 5月20日上午,郑州市教育局召开2026年郑州市中招工作会议。今年,郑州中招考试时间为6月22日-2...