MySQL:函数

1. 含义

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

2. 好处

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

3. 语法

创建

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

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

调用

SELECT 函数名(参数列表)

4. 实例

无参有返回

  • 案例:返回公司的员工个数
-- 创建
CREATE FUNCTION fun1 () RETURNS INT 
BEGIN

DECLARE result INT ;

SELECT 
  COUNT(*) INTO result 
FROM
  `employees` ;

RETURN result ;

END $ 
-- 调用
SELECT 
  fun1 () $

有参有返回

  • 案例:根据员工名返回工资
-- 创建
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') $ 

查看与删除

  • 查看
SHOW CREATE FUNCTION myf3 ;
  • 删除
DROP FUNCTION myf3 ;
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。