zoukankan      html  css  js  c++  java
  • MySQL之自定义函数实例讲解

    转自: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命令进行删除

  • 相关阅读:
    Arctic Network POJ
    Journey CodeForces
    Free Goodies UVA
    MU Puzzle HDU
    Balance POJ
    1sting 大数 递推
    最大报销额 暴力。。
    洛谷P2826 LJJ的数学课
    2018年12月29日
    2018年12月28日
  • 原文地址:https://www.cnblogs.com/sharpest/p/9936857.html
Copyright © 2011-2022 走看看