mysql数据库练习4-存储过程和存储函数
存储过程和存储函数语法
- 创建存储过程
create procedure p1(存储名)(in suppiler_num varchar(10))
begin
declare results int default 0; #声明变量并初始化
select count(*) into results #赋值
from factory.suppiler
where factory.suppiler.suppiler_num=suppiler_num;
select if (results>0,'成功','失败' ); #使用
end
(参数列表: 模式 参数名 参数类型)
模式 in(默认)、out、 inout:in 模式;out 模式;inout 模式
- 删除存储过程
drop procedure p1 (并且只能一次删除一个存储过程)
- 更改存储过程
不能直接修改存储过程,只能先删除该过程,在重新创建该过程
- 调用存储过程
call p1('s1')
注意:因为是in 模式所有可以传入常量,如果是inout模式
不可以传入常量,而必须是变量。
- 查看存储过程
show create procedure p1
存储函数
如果是第一次在mysql上创建存储函数,可能会发生SQL错误[1418][HY000]:
This function has none of DETERMINISTIC ,NO SQL,or READS SQL DATA in its declaration and binary logging is enabled(you “might” want to use the less safe_log_bin_trust_function_creators variable)。此时的mysql 服务器开启了二进制日志选项,这种模式是默认禁止创建存储函数的。
使用下列命令选择开启就可以了。
- 创建存储函数
create function 函数名(参数列表) returns 返回类型
begin
函数体
end
1、参数列表 (参数名 参数类型)
2、 函数体肯定有return 语句
- 调用存储函数
select 函数名(参数列表)
案例演示
有一简易电子商务网站,其平台数据库中部分表及其结构如下:
(1)用户表:tUser(用户账号varchar(10),用户名称varchar(50),登陆密码varchar(20),联系电话varchar(20),邮件地址varchar(100),已购商品总额numeric(10,2),送货地址varchar(100))
(2)用户登录历史记录表:tUserHisRec(登录序号int identity(1,1),用户账号varchar(10),登录时间datetime)
(3)商品列表:productsList(商品编号varchar(20),商品名称varchar(100),商品类别varchar(100),商品价格numeric(10,2),出厂日期datetiem,生产商varchar(200))
(4)用户购买商品记录:tUserOrder(登陆序号int identity(1,1),用户账号varchar(10),商品编号varchar(20),购买时间datetime,送货地址varch