MySQL笔记 21:函数

it2023-01-21  59

1. 含义

一组预先编译好的SQL语句的集合函数与存储过程的不同点在于:存储过程可以有多个返回,但是函数有且仅有一个返回存储过程适合做批量的增删改操作,函数适合处理数据返回一个结果这种需求

2. 好处

提高代码的重用性简化操作减少了编译次数并且减少了和数据库服务器的连接次数,提高了效率

3. 语法


3.1 创建

CREATE FUNCTION 函数名(参数列表) RETURNS 返回类型 BEGIN -----函数体----- END

注意:

参数列表包含两部分:参数名 参数类型函数体:肯定有return语句,如果没有会报错如果函数体只有一条语句,则BEGIN和END可以省略函数中的每条SQL语句的结尾要求必须加分号,存储过程的结尾可以使用 DELIMITER 重新设置,例:DELIMITER $

3.2 调用

SELECT 函数名(参数列表)

4. 实例


4.1 无参有返回

案例:返回公司的员工个数

-- 创建 CREATE FUNCTION fun1 () RETURNS INT BEGIN DECLARE result INT ; SELECT COUNT(*) INTO result FROM `employees` ; RETURN result ; END $ -- 调用 SELECT fun1 () $

4.2 有参有返回

案例:根据员工名返回工资

-- 创建 CREATE FUNCTION fun2 (`name` VARCHAR (25)) RETURNS DOUBLE BEGIN DECLARE result DOUBLE ; SELECT `salary` INTO result FROM `employees` WHERE `last_name` = `name` ; RETURN result ; END $ -- 调用 SELECT fun2 ('Kochhar') $

案例:根据部门名返回该部门的平均工资

-- 创建 CREATE FUNCTION fun4 (`dept_name` VARCHAR (3)) RETURNS DOUBLE (10, 2) BEGIN DECLARE result DOUBLE ; SELECT AVG(`salary`) INTO result FROM `employees` AS e INNER JOIN `departments` AS d ON e.`department_id` = d.`department_id` WHERE d.`department_name` = `dept_name` GROUP BY d.`department_id` ; RETURN result ; END $ -- 调用 SELECT fun4 ('Shi') $

4.3 查看与删除

查看

SHOW CREATE FUNCTION myf3 ;

删除

DROP FUNCTION myf3 ;
最新回复(0)