【MySql存储过程】存储过程优缺点、语法结构、权限、修改、删除储过程

存储过程

为什么要存储过程

1.减少网络流量

2.提高执行速度

3.减少数据库连接次数

4.安全性高

5.高复用

缺点

可移植性差

#创建存储过程
DELIMITER//
CREATE PROCEDURE 
	proc_patient_patientCount2(OUT patientNum INT)
	BEGIN
	SELECT COUNT(*) INTO patientNum FROM patient;
	END //
DELIMITER;
#调用存储过程
CALL  proc_patient_patientCount2(@patientCount)	#接受输出的变量
SELECT @patientCount;	#查看变量
语法结构
CREATE PROCEDURE 过程名 ([过程参数[,...]])
	[特征]
	BEGIN
		存储过程
	END
	
存储过程权限

DEFINER

1.默认 DEFINER = CURRENT_USER

2.检查’user_name’@'host_name’的权限

INVOKER

执行存储过程时,会检查调用者的权限

查看数据库中已创建的存储过程
SHOW PROCEDURE STATUS;
SHOW PROCEDURE STATUS LIKE ‘%patient%’;
查看数据库中已创建的存储过程代码
SHOW CREATE PROCEDURE proc_pp1
修改存储过程

ALTER PROCEDURE 存储过程名 [特性…]

删除存储过程

DROP PROCEDURE 存储过程名

删除已存在的存储过程proc_calc_patient_avg_cost

DROP PROCEDURE IF EXISTS proc_calc_patient_avg_cost;

IFELSE语法
IF 条件 THEN 语句列表
	[ELSEIF 条件 THEN 语句列表]
	[ELSE 语句列表]
END IF;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值