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 ;