MySQL中的存储过程和函数使用详解

 一.对待存储过程和函数的态度

在实际项目中应该尽量少用存储过程和函数,理由如下:

1.移植性差,在MySQL中的存储过程移植到sqlsever上就不一定可以用了。

2.调试麻烦,在db中报一个错误和在应用层报一个错误不是一个概念,那将是毁灭性打击,直接一个error:1045什么的更本毫无头绪。

3.扩展性不高

所以在互联网时代大型项目应该尽量少使用(不使用)存储过程和函数。

二.创建存储过程

2.1什么是存储过程?

存储过程和存储函数都是一组sql语句的集合。这些语句集合被当做一个整体存入数据库中。

2.2创建存储过程的语法:

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

                    sql语句

例子:

复制代码
delimiter // create procedure pro() reads sql data begin select * from stu; end //
复制代码

那么我们现在就有一个存储过程pro了,但是这个存储过程他是没有参数的,他只是执行一次查询操作。

我们现在来讲解一下这个存储过程的结构:

delimiter //  是将分号转化为//   因为在sql执行时当他遇到分号 ; 时他就讲停止所以我们必须将其转化为 //直到最后一行才会停止执行。

reads sql  data   解释characteristic的状态在这里是只读模式,其他的模式还有:no sql 没有sql语句 , ins  sql 不包含读和写的语句 , modifies sql data   包含写入数据的语句等等。

begin /***/  end   在存储过程中当有多条语句集合时我们必须使用begin和end

//   结束整个存储过程

2.3使用存储过程

在只是创建了一个存储过程,那么我们怎么来使用这个存储过程呢?

语法:call  存储过程名()

将上一个存储过程pro使用的例子:

call pro();

 

2.4创建一个带参数的存储过程

参数列表:存储过程的参数有三种类型:in,out,inout 分别表示传入参数和传出参数,和即传入也传出参数。

例子:首先我们来创建两张表:课程表是学生表的从表

复制代码
create table stu( stu_id bigint primary key auto_increment,#学号 stu_name varchar(10) not null,#姓名 stu_major int not null,#专业号 stu_sex char,#性别 stu_in date,#入学日期 stu_birth date,#出生日期 foreign key (stu_major) references major(ma_id)#专业外键设置 );
create table major( ma_id int primary key, ma_name varchar(15), ma_boss varchar(10) );
insert into major values(
                        
关键字:
50000+
5万行代码练就真实本领
17年
创办于2008年老牌培训机构
1000+
合作企业
98%
就业率

联系我们

电话咨询

0532-85025005

扫码添加微信