目标

如何在MySQL数据库中创建函数(Function)

语法

[sql] view plaincopy print?
  1. CREATE FUNCTION func_name ( [func_parameter] ) //括号是必须的,参数是可选的
  2. RETURNS type
  3. [ characteristic ...] routine_body
  • CREATE FUNCTION 用来创建函数的关键字;
  • func_name 表示函数的名称;
  • func_parameters为函数的参数列表,参数列表的形式为:[IN|OUT|INOUT] param_name type
  1. IN:表示输入参数;
  2. OUT:表示输出参数;
  3. INOUT:表示既可以输入也可以输出;
  4. param_name:表示参数的名称;
  5. type:表示参数的类型,该类型可以是MySQL数据库中的任意类型;
  • RETURNS type:语句表示函数返回数据的类型;
  • characteristic: 指定存储函数的特性,取值与存储过程时相同,详细请访问-MySQL存储过程使用;

示例

创建示例数据库、示例表与插入样例数据脚本:

[sql] view plaincopy print?
  1. create database hr;
  2. use hr;
  3. create table employees
  4. (
  5. employee_id int(11) primary key not null auto_increment,
  6. employee_name varchar(50) not null,
  7. employee_sex varchar(10) default '男',
  8. hire_date datetime not null default current_timestamp,
  9. employee_mgr int(11),
  10. employee_salary float default 3000,
  11. department_id int(11)
  12. );
  13. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('David Tian','男',10,7500,1);
  14. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Black Xie','男',10,6600,1);
  15. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Moses Wang','男',10,4300,1);
  16. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Rena Ruan','女',10,5300,1);
  17. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Sunshine Ma','女',10,6500,2);
  18. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Scott Gao','男',10,9500,2);
  19. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Warren Si','男',10,7800,2);
  20. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Kaishen Yang','男',10,9500,3);
  21. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Simon Song','男',10,5500,3);
  22. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Brown Guan','男',10,5000,3);
  23. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Eleven Chen','女',10,3500,2);
  24. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Cherry Zhou','女',10,5500,4);
  25. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Klause He','男',10,4500,5);
  26. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Maven Ma','男',10,4500,6);
  27. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Stephani Wang','女',10,5500,7);
  28. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Jerry Guo','男',10,8500,1);
  29. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Gerardo Garza','男',10,25000,8);
  30. insert into employees(employee_name,employee_sex,employee_mgr,employee_salary,department_id) values ('Derek Wu','男',10,5500,5);
  31. select * from employees;

创建函数-根据ID获取员工姓名与员工工资

[sql] view plaincopy print?
  1. DELIMITER //
  2. CREATE FUNCTION GetEmployeeInformationByID(id INT)
  3. RETURNS VARCHAR(300)
  4. BEGIN
  5. RETURN(SELECT CONCAT('employee name:',employee_name,'---','salary: ',employee_salary) FROM employees WHERE employee_id=id);
  6. END//
  7. DELIMITER ;

调用函数

在mysql——函数的使用方法与MySQL内部函数的使用方法一样。

转载于:https://www.cnblogs.com/mafeng/p/7121473.html

[置顶] MySQL -- 创建函数(Function相关推荐

  1. MySQL 创建函数(Function)

    目标 如何在MySQL数据库中创建函数(Function) 语法 CREATE FUNCTION func_name ( [func_parameter] ) //括号是必须的,参数是可选的 RETU ...

  2. 数据库系列之mysql 自定义函数function,函数和存储过程的区别

    mysql 自定义函数function,函数和存储过程的区别 https://blog.csdn.net/u010365819/article/details/80470448 https://blo ...

  3. MySQL 创建函数, MySQL定义函数实现汉字转拼音 MySQL汉字转拼音MySQL汉字生成拼音字符串

    MySQL 创建函数, MySQL定义函数实现汉字转拼音 MySQL汉字转拼音 一.MySQL创建函数 1.语法 CREATE FUNCTION fun_name([paramName type , ...

  4. MySQL创建函数报“ERROR 1418 ”错误,不能创建函数

    MySQL创建函数报ERROR 1418错误,不能创建函数,根据官方提示是说,不能创建函数可能是一个安全设置方面的配置或功能未开启原因,下面我们一起来看. 错误 ERROR 1418 (HY000): ...

  5. mysql创建函数失败_MYSQL创建函数出错如何解决

    在使用MySQL数据库时,有时会遇到MySQL函数不能创建的情况.下面就教您一个解决MySQL函数不能创建问题的方法,供您借鉴参考.希望能帮助到大家. 案例一: 目前在项目中,执行创建mysql的函数 ...

  6. MySQL创建函数和存储过程,批量插入大数据

    工作中使用Jmeter压测时,需要大数据量,可以使用MySQL创建函数和存储过程,批量插入大数据 右击新建函数,创建过程 完成后自动创建 在body部分写入过程: DECLARE id INT DEF ...

  7. 在navicat for mysql 创建函数,保存的时候出现1064错误

    在navicat for mysql 创建函数,保存的时候出现1064错误 解决方法:很有可能是mysql语句出现语法错误,仔细检查一下符号是否为英文,是否忘记写符号":"

  8. mysql 自定义函数function,函数和存储过程的区别

    From: https://blog.csdn.net/u010365819/article/details/80470448 1.MySQL自定义函数简介 在MySQL中使用自定义函数也需要相应的要 ...

  9. mysql创建函数1418_Mysql中创建函数报“ERROR 1418 ”的解决方法

    我们在使用mysql数据库开发项目的时候,有时Mysql系统自带的函数不能完全满足我们开发的需要,解决方法是自己创建函数,可以有可能在你创建函数的过程事会报出Error 1418错误,对于报这种错误的 ...

  10. mysql创建反弹函数,MySql创建函数

    首先需要查看一下创建函数的功能是否开启: X:\proper\mysql\bin>mysql -h localhost -u root -p Enter password: ********** ...

最新文章

  1. mysql常见日期查询问题
  2. Sencha Touch 2 DataView / List 分页
  3. python最低薪资_Python最低薪资在北上深是多少你们知道吗?我已经整理好了哦
  4. Magicodes.IE 2.5.4.2发布
  5. Asp.Net Core 中IdentityServer4 授权中心之应用实战
  6. IOS学习笔记之十一(包装类、description、isequal)
  7. 微课|中学生可以这样学Python(7.3.3节):成员方法、类方法、静态方法
  8. 状态服务器与无状态服务器(要点)
  9. python绘制turtle心电图代码_python的生态系统是由标准库和第三方库组成的,turtle库是其标准库,所以不需要安装。_学小易找答案...
  10. 2021-秋招你准备好了吗?软件测试面试题
  11. NYOJ 214(LIS,二分插入)
  12. 查看系统使用率命令 vmstat 输出详解!
  13. matlab画散点图
  14. 弱电从业人员必须学习的一些CAD绘图技巧
  15. 厦大C语言上机 1394 抛硬币
  16. Windows10使用自带表情包
  17. SpringBoot + Java生成证书
  18. 中国卖家如何在亚马逊平台玩转“无货源模式”10人团队产值30-50w
  19. 【AAAI 2021】跨层知识蒸馏:Cross-Layer Distillation with Semantic Calibration
  20. 学习java必读书籍

热门文章

  1. Win7从VHD中启动 如何扩充虚拟磁盘
  2. 算法在岗3年小结:模型策略篇
  3. 原来神经网络是一种图?
  4. numpy—np.info(function)
  5. pyspark用法2
  6. LeetCode学习记录(4-6)
  7. C/C++中存储区域
  8. 【重磅预告】揭秘阿里双11技术进步历程!
  9. 技术改变世界以及减速慢行
  10. 5.7 tensorflow2实现主成分分析(PCA) ——python实战(上篇)