MySQL中函数、存储过程的创建、删除与查看

创建函数

DELIMITER $   //设置$为结束标识
CREATE FUNCTION 方法名() 返回值类型
BEGIN
	//函数体...
END $

示例1:无参返回,返回emp表中数据的个数

DELIMITER $
CREATE FUNCTION getCount() RETURNS INT
BEGIN
	SET @a = 0;    #定义变量
	SELECT COUNT(*) INTO @a #查询结果值给到变量
	FROM emp;
	RETURN @a;   #返回变量值
END $

示例2:有参返回,输入部门编号,返回部门平均工资

DELIMITER $
CREATE FUNCTION avgSalary(id INT) RETURNS DOUBLE
BEGIN
	SET @x = 0; #定义变量
	SELECT AVG(salary) INTO @x #查询结果值给到变量
	FROM emp
	GROUP BY deparid
	HAVING deparid = id;
	RETURN @x;  #返回变量值
END $

使用函数

SELECT 函数名(参数列表);

示例

show getCount();
show avgSalary(1);

查看函数

//查看所有函数
SHOW FUNCTION STATUS; 
//查看指定
SHOW CREATE FUNCTION 函数名;

示例

show CREATE FUNCTION getCount;
show CREATE FUNCTION avgSalary;

删除函数

DROP FUNCTION 函数名;

示例

DROP FUNCTION getCount;
DROP FUNCTION avgSalary;

创建存储过程

DELIMITER $
CREATE PROCEDURE 名称(参数)
BEGIN
	//存储过程体...
END $

示例1:无参无返回值,批量插入数据

DELIMITER $
CREATE PROCEDURE insertAdmin()
BEGIN
	INSERT INTO admin VALUES
	(1,'Tom',15,160),
	(2,'Tom',15,1580),
	(3,'Tom',19,1586),
	(4,'Tom',15,15860);
END $

示例2:有参无返回值,通过女孩的名字查询id对应的男孩

DELIMITER $
CREATE PROCEDURE selectBoyGirl(IN `name` VARCHAR(8))
BEGIN
	SELECT boys.*
	FROM girls
	JOIN boys
	ON girls.`id`=boys.`id`
	WHERE `name`=girls.`name`;
END $

示例3:有参有返回值,通过女孩的名字查询id对应的男孩,并返回男孩名字。

IN:代表输入参数
OUT:代表返回值

CREATE PROCEDURE selectBoyGirl2(IN `name` VARCHAR(8),OUT boyName VARCHAR(8))
BEGIN
	SELECT boys.`name` INTO boyName
	FROM boys
	INNER JOIN girls
	ON boys.`id`=girls.`id`
	WHERE `name`=girls.`name`;
END $

调用存储过程

CALL 存储过程名称(参数);

示例

CALL insertAdmin();

CALL selectBoyGirl('苍老师');

SET @bName; //先定义变量
CALL selectBoyGirl2('苍老师',@bName);

删除存储过程

DROP PROCEDURE 名称;

示例

DROP PROCEDURE insertAdmin;
DROP PROCEDURE selectBoyGirl;
DROP PROCEDURE selectBoyGirl2;

查看存储过程

//查看所有存储过程
SHOW PROCEDURE STATUS;
//查看指定
SHOW CREATE PROCEDURE 名称;

示例

SHOW CREATE PROCEDURE insertAdmin;
SHOW CREATE PROCEDURE selectBoyGirl;
SHOW CREATE PROCEDURE selectBoyGirl2;

函数与存储过程的对比

存储过程:返回0个或多个,适合做批量插入,更新。
调用使用CALL

函数:有且仅有一个返回,适合做数据处理返回一个结果
调用使用SELECT

都使用DELIMITER设置结尾$

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值