欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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

程序员文章站 2024-03-20 09:20:04
...

创建函数

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设置结尾$