MySQL之运算符与函数、自定义函数

 一自定义函数简介

        (1)自定义函数定义

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

        (2)自定义函数的两个必要条件

        1)参数:能够有零个或多个。函数

        2)返回值:只能有一个返回值。.net

       使用自定义函数的注意事项get

       1)全部函数都有返回值,但不必定都有参数。it

       2)函数的参数与返回值之间没有必然的内在联系。io

       3)函数能够返回任意类型的值,一样能够接收这些类型的参数。function

       (3)建立自定义函数

       建立自定义函数的语法结构:class

       CREATE FUNCTION function_name RETURNS {STRING|INTEGER|REAL|DECIMAL} routine_body;test

       (4)函数体

       1)函数体由合法的SQL语句构成。扩展

       2)函数体能够是简单的SELECT或INSERT语句。

       3)函数体若是为复合结构则使用BRGIN...END语句。

       4)复合结构能够包含声明,循环,控制结构。

       二建立不带参数的自定义函数

       实例:

       查看当前日期时间和格式化当前时间

       SELECT NOW();

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

       对于习惯使用日期时间的来讲,咱们并不习惯上面的第一个,第二个格式化后的时间咱们比较认同。每次都去格

式化日期时间会比较麻烦,所以咱们考虑把这个过程自定义为一个函数。

       将上面的过程封装为一个函数

       CREATE FUNCTION f1() RETURNS VARCHAR(30) RETURN DATE_FORMAT(NOW(),'%Y年%m月%d日 %H

点:%i分:%s秒');

       调用函数

       SELECT f1();

       三建立带有参数的自定义函数

       自定义一个求两个数的平均数的函数,要求结果保留两位小数。

       CREATE FUNCTION f2(num1 SMALLINT UNSIGNED,num2 SMALLINT UNSIGNED) RETURNS  FLOAT(10,2)

 UNSIGNED RETURN (num1+num2)/2;

       调用函数

       SELECT f2(10,15);

       四建立具备复合结构函数体的自定义函数

       自定义一个返回最后插入数据表的记录而且返回最后一个插入的ID号的函数

       USE t1;

       SELECT * FROM test;

       CREATE FUNCTION adduser(username VARCHAR(20)) RETURNS  INT  UNSIGNED BEGIN INSERT 

test(username) VALUES(username); RETURN LAST_INSERT_ID(); END;

       上面报错的缘由是MySQL语句结束符号报错,咱们日常通常的MySQL语句都是以;结束,可是复合结构中包括插

入语句,查询语句等子SQL语句,而每一个语句都会以;结束,所以MySQL数据库的客户端只会识别第一个;号,后面的

内容再也不读取,所以形成语句出错。

       咱们作出如下修改:

       修改语句的结束符号

        DELIMITER //

        建立自定义函数

        CREATE FUNCTION adduser(username VARCHAR(20)) RETURNS  INT  UNSIGNED BEGIN INSERT 

test(username) VALUES(username); RETURN LAST_INSERT_ID(); END//

        DELIMITER ;

        调用函数

        SELECT adduser('Lee');

        SELECT * FROM test;

        五自定义函数的查找

        自定义函数的查找

        SHOW FUNCTION STATUS\G;

        六删除函数

        删除函数的语法结构:

        DROP FUNCTION [IF EXISTS] function_name;

相关文章
相关标签/搜索