自定义函数

自定义函数
用户自定义函数(user-defined function,UDF)是一种对MySQL扩展的途径,其用法与内置函数相同

自定义函数的两个必要条件:
1.参数
2.返回值

函数可以返回任意类型的值,同样可以接受这些类型的参数
创建自定义函数


image.png

关于函数体
1.函数体由合法的SQL语句构成
2.函数体可以是简单的select或insert语句
3.函数体如果为复合结构则使用begin...end语句
4.复合结构可以包含声明,循环,控制结构

mysql> create function f1() returns varchar(30)
    -> return date_format(now(),'%Y年%m月%d日 %H点:%i分:%s秒');
Query OK, 0 rows affected (0.00 sec)

mysql> select f1();
+-------------------------------------+
| f1()                                |
+-------------------------------------+
| 2018年03月09日 10点:43分:30秒       |
+-------------------------------------+
1 row in set (0.00 sec)

ps 先要修改编码方式
mysql> set names utf8;
然后还有删除函数的方法
mysql> drop function f1;

mysql> create function f2(num1 smallint unsigned,num2 smallint unsigned)
    -> returns float(10,2) unsigned
    -> return (num1+num2)/2;
Query OK, 0 rows affected (0.01 sec)
mysql> select f2(10,5);
+----------+
| f2(10,5) |
+----------+
|     7.50 |
+----------+
1 row in set (0.02 sec)

returns + 类型
return + 内容

image.png
mysql> delimiter //      //修改结束符为'//'
mysql> create function adduser(first_name varchar(20))
    -> returns int unsigned
    -> begin
    -> insert test(first_name)values(first_name);
    -> return last_insert_id();
    -> end
    -> //

ps 假如有两条以上的语句就要使用begin...end语句

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

推荐阅读更多精彩内容

  • 1、自定义函数 用户自定义函数(user-defined function,UDF)是一种对MySQL扩展的途径,...
    黒猫阅读 633评论 0 1
  • 回顾和概述 内置函数库: 字符函数 数值函数 日期时间函数 加密函数 如果需要一些系统没有提供的函数,就需要自定义...
    齐天大圣李圣杰阅读 459评论 0 0
  • 参考MySQL官方文档 一、常见内置函数 从文档列表可知,MySQL内置函数涵盖范围非常广:控制流函数、字符串函数...
    maxwellyue阅读 1,865评论 0 6
  • 本文为《爬着学Python》系列第十篇文章。 在实际操作中,可能函数是我们几乎唯一的实现操作的方式,这是因为函数能...
    SyPy阅读 5,559评论 0 8
  • 七区七号楼是一栋三层、仿照苏联早期建筑形式、建于上世纪五十年代的筒子楼。共四个楼门,我家住一号门三层。 楼梯将长长...
    好一而博阅读 515评论 0 1