转自:https://www.2cto.com/database/201804/740205.html

MySQL中已经有很多函数,如时间函数等,但是有时这些函数不能满足自己的设计需求,此时需要自定义函数,用户自定义函数(User-defined functuin,UDF)是对MySQL的扩展,其用法和内置函数相同

函数需要具备:参数 返回值

对于函数体中的部分可以是:

1、函数体由合法的SQL语句组成

2、函数体可以是简单的select或者insert语句

3、函数体若为复合结构则使用begin...end语句

4、复合结构可以包含声明、循环、控制结构

1、无参数

知道通过now()函数可以显示日期和时间,如果想把这个时间表达成:“年月日时分秒” 的形式怎么办呢?通过使用格式化函数DATE_FORMAT()

1
mysql> select DATE_FORMAT(NOW(),'%Y年%m月%d日 %H点:%i分:%s秒');

由于该过程书写较为麻烦,如果经常使用很不方便,因此将其“制作”成函数

1
2
mysql> create FUNCTION f1() returns varchar(30)
    -> RETURN DATE_FORMAT(NOW(),'%Y年:%m月:%d日 %H点:%i分:%s秒');

由于在定义f1()的时候没有参数,因此调用时就可以直接调用

1
mysql> select f1();

2、带有参数

带有一个以上的参数时,这里求解两个数的平均数

1
2
3
mysql> create FUNCTION f2(num1 smallint unsigned,num2 smallint unsigned)  #函数名
    -> RETURNS FLOAT(10,2) UNSIGNED       #返回值的类型
    -> RETURN (num1+num2)/2;              #返回值

3、创建具有复合结构的函数

首先创建一个数据表test

1
2
3
root@localhost test>create table test(id tinyint(3) unsigned primary key auto_increment,
    -> username varchar(30) not null
    -> );

现在想往数据表中插入记录,返回值是新插入的记录的id号

1
root@localhost test>insert into test values(default,'Lj.K');

由于分号是命令的结束,因此这里需要修改默认的分隔符,否则在输入分号之后无法返回新插入记录的id,因此使用命令

1
DELIMITER 分隔符

这样所有的命令均需要以分隔符来结束

比这将分隔符修改为//,则所有命令均需要以 // 为结束

1
2
3
4
5
6
7
root@localhost test>create FUNCTION adduser(username varchar(20))  #创建添加参数名为username的函数adduser
    -> RETURNS INT UNSIGNED
    -> BEGIN
    -> INSERT test(username) VALUES(username);
    -> RETURN LAST_INSERT_ID();
    -> END
    -> //

这里因为有两条语句 insert test(username) values(username)和return last_insert_id()两条语句要执行,因此需要使用BEGIN...END语句,从而构成聚合体

1
2
root@localhost test>select  adduser('Rose');
    -> //

1
2
root@localhost test>DELIMITER ;
root@localhost test>select  adduser('Tom');

通过drop function命令进行删除

最新文章

  1. linux字符串url编码与解码
  2. LINUX测试环境部署mysql(三)
  3. 初学PHP
  4. Java-URLConnection类详解
  5. 十、ios 模态窗口[实例]
  6. 【ExtJs】使用Cookie、切换主题和语言
  7. android strings.xml转义字符, 注意细节解决(转)
  8. (Qt 翻译) QGLSceneNode
  9. SQL注入的原理解说,挺好!
  10. c# winform 引用sqlite.dll 运行报错解决方法
  11. iOS常用宏定义
  12. 【java】实现Interface java.lang.Comparable<T>接口的int compareTo(T o)方法实现对象数组或链表或集合的排序,和挽救式对象比较器Interface java.util.Comparator<T>
  13. numpy 解一道简单数学题
  14. HttpClient方式调用接口的实例
  15. vue端口号被占用如何解决
  16. anaconda利用pip安装module
  17. winform 点击控件拖动窗体
  18. Zabbix-2.4-安装-1
  19. java 小程序查看器 启动:未初始化小程序 解决方法
  20. Linux Kernel系列三:Kernel编译和链接中的linker script语法详解

热门文章

  1. 习题练习(视觉slam14讲课后习题)
  2. Linux kernel memory-faq.txt
  3. [转载] Linux Futex的设计与实现
  4. linux less-分屏上下翻页浏览文件内容
  5. Glossary in Turbulence
  6. pandas处理各类表格数据
  7. LINUX应用开发工程师职位(含答案)
  8. PAT 1141 PAT Ranking of Institutions
  9. spark之scala快速入门
  10. Linux下汇编语言学习笔记80 ---