MySQL存储过程

《MySQL存储过程》要点:
本文介绍了MySQL存储过程,希望对您有用。如果有疑问,可以联系我们。

存储过程的好处:

  1. 业务逻辑被“暗藏”在数据库里面,从而避免敏感的数据被透露

  2. 能简化应用法式代码

  3. 跨平台性

  4. 如果您必需一次执行几个语句,一个存储过程比客户端程序逐条地执行语句要快的多,因为不需要任何的来往返数据

CREATE

[DEFINER = {user | CURRENT_USER}]

PROCEDURE<name> (PARAMETER(S)...)

[characteristic(s)...] routine_body

The syntax for creating a function is:

CREATE

[DEFINER = {user | CURRENT_USER }]

FUNCTION sp_name ([parameter])

RETURNS type

[characteristic(s)...] routine_body

  • CREATE 创立

  • DEFINER 定义者,表现存储过程或者函数的所有者,如果省略,讲使用默认所有者(当前用户)

  • RPOCEDURE<name> 表现创建一个名字为name的存储过程

  • FUNCTION<name> 表现创建一个名称为name的函数

【IN | OUT | INOUT】<parameter name> type

  • IN 指参数是一个输入变量,它仅向过程提供一个值

  • OUT 指参数是只是用来存储返回值

  • INOUT 指参数可用于输入变量和返回值

  • parameter name(参数名称)是Type的类型名

  • RETURNS 表现返回数据类型

  • DETERMINISTIC 确定性

  • NOT DETERMINISTIC 非确定性

实例一、

CREATE PROCEDURE user_avg(OUT average NUMERIC(5,2))

BEGIN

SELECT AVG(age) INTO average FROM users

END;

执行该存储过程:

CALL user_avg(@a);

SELECT @a;

实例二、

CREATE FUNCTION is_young(uuname VARCHAR(64))

RETURNS BOOLEAN

DETERMINISTIC

BEGIN

DECLARE age_check DECIMAL(5,2);

DECLARE is_young BOOLEAN;

SELECT age INTO age_check FROM users WHERE username =uuname;

IF (age_check<40) THEN

SET is_young =1;

ELSE

SET is_young =0;

END IF;

RETURN(is_young);

END

MySQL存储过程

数据库存在的admin1的时候返回1

MySQL存储过程

数据库不存在的admin11的时候返回0

每天三分钟,知识效率高.轻文章,更高效.

欢迎存眷同名微信公众账号DevOps24h.

《MySQL存储过程》是否对您有启发,欢迎查看更多与《MySQL存储过程》相关教程,学精学透。编程之家PHP学院为您提供精彩教程。

相关文章

navicat查看某个表的所有字段的详细信息 navicat设计表只能一...
文章浏览阅读4.3k次。转载请把头部出处链接和尾部二维码一起...
文章浏览阅读488次。恢复步骤概要备份frm、ibd文件如果mysql...
文章浏览阅读225次。当MySQL单表记录数过大时,增删改查性能...
文章浏览阅读1.5k次。Mysql创建、删除用户MySql中添加用户,新...
MySQL是一种开源的关系型数据库管理系统,被广泛应用于各类应...