转载地址:http://www.2cto.com/database/201212/177382.html
一、自定义函数(UDF)的特性和功能  www.2cto.com  
        函数能分返回字符串,整数或实数;
        可以定义一次作用于一行的简单函数,或作用于多行的组的集合函数;
二、基本操作
1、创建自定义函数
        CREATE [AGGREGATE] FUNCTION function_name RETURNS {STRING|INTEGER|REAL}
        BEGIN
            //函数实现的语句
        END;
        aggregate 指定创建的函数是普通的自定义函数,还是AGGREGATE函数。
        function_name 是用在SQL声明中以备调用的函数名字。
        RETURNS 子句说明函数返回值的类型。 
        每次服务器启动的时候会重新加载所有有效函数,除非使用--skip-grant-tables参数启动mysqld。在这种情况下, 将跳过UDF的初始化,UDF不可用。
        一个AGGREGATE函数就像一个MySQL固有的集合(总和)函数一样起作用,比如,SUM或COUNT()函数。要使得AGGREGATE 起作用,mysql.func表必须包括一个type列。如果mysql.func表没有这一 列,则应该运行mysql_fix_privilege_tables脚本来创建此列。
        示例:
[sql] 
mysql> delimiter //  
mysql> create function fun_add_rand(  
    ->     in_int int  
    -> )  
    -> RETURNS int  
    -> BEGIN  
    ->     declare i_rand int;  
    ->     declare i_return int;  
    ->  
    ->     set i_rand=floor(rand()*100);  
    ->     set i_return = in_int + i_rand;  
    ->  
    ->     return i_return;  
    -> END;  
    -> //  
mysql> delimiter ;  
 
2、使用自定义函数
        示例:
[sql] 
mysql> select id from test_inn;  
 +------+  
 | id   |  
 +------+  
 |    1 |  
 |    1 |  
 |    1 |  
 |    1 |  
 +------+  
 mysql> select fun_add_rand(id) from test_inn;  
 +------------------+  
 | fun_add_rand(id) |  
 +------------------+  
 |               91 |  
 |               34 |  
 |               93 |  
 |               66 |  
 +------------------+  
 
3、删除自定义函数
        DROP FUNCTION [ IF EXISTS ] function_name;
        示例:
[sql] 
mysql> drop function if exists fun_add_rand;  
 
4、查看自定义函数创建信息
        SHOW CREATE FUNTION function_name;
        示例:
[sql] 
mysql> show create function fun_add_rand;                                                                                                                   
+--------------+----------+-----------------------------------------------------------+----------------------+----------------------+--------------------+  
| Function     | sql_mode | Create Function                                           | character_set_client | collation_connection | Database Collation |  
+--------------+----------+-----------------------------------------------------------+----------------------+----------------------+--------------------+  
| fun_add_rand |          | CREATE DEFINER=`root`@`localhost` FUNCTION `fun_add_rand`(                                                                      
    in_int int                                                                      
) RETURNS int(11)                                                                      
BEGIN                                                                      
    declare i_rand int;                                                                      
    declare i_return int;                                                                      
                                                                      
    set i_rand=floor(rand()*100);                                                                      
    set i_return = in_int + i_rand;                                                                      
                                                                      
    return i_return;                                                                      
END | latin1               | latin1_swedish_ci    | latin1_swedish_ci  |                                                                      
+--------------+----------+-----------------------------------------------------------+----------------------+----------------------+--------------------+  
 
5、查看自定义函数状态
        SHOW FUNCTION STATUS [ LIKE '' ];
        示例:
[sql] 
mysql> show function status like 'fun%';  
+------+--------------+----------+----------------+---------------------+---------------------+---------------+  
| Db   | Name         | Type     | Definer        | Modified            | Created             | Security_type |  
+------+--------------+----------+----------------+---------------------+---------------------+---------------+  
| test | fun_add_rand | FUNCTION | root@localhost | 2012-12-18 20:08:50 | 2012-12-18 20:08:50 | DEFINER       |  
+------+--------------+----------+----------------+---------------------+---------------------+---------------+ 

【转】MYSQL入门学习之十三:自定义函数的基本操作的更多相关文章

  1. 【转】MYSQL入门学习之十:视图的基本操作

    转载地址:http://www.2cto.com/database/201212/176775.html 一.视图的基本介绍  www.2cto.com           视图是虚拟的表.与包含数据 ...

  2. 【转】MYSQL入门学习之十一:触发器的基本操作

    转载地址:http://www.2cto.com/database/201212/176781.html 触发器是MySQL响应以下任意语句而自动执行的一条MySQL语句(或位于BEGIN和END语句 ...

  3. 【数据库】9.0 MySQL入门学习(九)——获得数据库和表的信息、日期计算、查询、选择特殊列

    1.0 SELECT语句用来从数据表中检索信息. SELECT what_to_select FROM which_table WHERE conditions_to_satisfy; what_to ...

  4. shell学习总结之自定义函数

    shell学习总结之自定义函数 Myfun (){ echo -n "now i is $i " ! [ "$i" ] && exit ; ec ...

  5. 【数据库】7.0 MySQL入门学习(七)——MySQL基本指令:帮助、清除输入、查询等

    1.0 help == ? 帮助指令,查询某个指令的解释.用法.说明等.详情参考博文: [数据库]6.0 MySQL入门学习(六)——MySQL启动与停止.官方手册.文档查询 https://www. ...

  6. 【数据库】4.0 MySQL入门学习(四)——linux系统环境下MySQL安装

    1.0 我的操作系统是CentOS Linux release 7.6.1810  (Core) 系统详细信息如下: Linux version 3.10.0-957.1.3.el7.x86_64 ( ...

  7. 【数据库】3.0 MySQL入门学习(三)——Windows系统环境下MySQL安装

    1.0 我的操作系统是window10 专业版 64位.,不过至少windows7以上系统都是一样的. 关于MySQL如何下载,请参考博文: [数据库]2.0 如何获得MySQL以及MySQL安装 h ...

  8. MySQL全面瓦解18:自定义函数

    定义 我们之前学习了MySQL的内置函数,非常丰富,满足了我们对数据操作的大部分需求. 但是如果有一些复杂的业务逻辑在数据库层面就可以完成,无需在程序层面完成的时候,这时候就可以写成MySQL自定义函 ...

  9. 【mysql的编程专题⑤】自定义函数

    用户自定义函数(user-defined function,UDF) 是一种对mysql的扩展途径,其用法与内置函数相同 创建自定义函数 语法 create function function_nam ...

随机推荐

  1. C# 集合-并发处理-锁OR线程

    每次写博客,第一句话都是这样的:程序员很苦逼,除了会写程序,还得会写博客!当然,希望将来的一天,某位老板看到此博客,给你的程序员职工加点薪资吧!因为程序员的世界除了苦逼就是沉默.我眼中的程序员大多都不 ...

  2. 使用ajax请求,模态框调用并更改密码

    前端页面 <a href="javascript:void(0);" onclick="changPassword()"> <i class= ...

  3. Java基础之在窗口中绘图——使用模型/视图体系结构在视图中绘图(Sketcher 1 drawing a 3D rectangle)

    控制台程序. 在模型中表示数据视图的类用来显示草图并处理用户的交互操作,所以这种类把显示方法和草图控制器合并在一起.不专用于某个视图的通用GUI创建和操作在SketcherFrame类中处理. 模型对 ...

  4. Swift游戏实战-跑酷熊猫 03 熊猫跑动动画

    这节内容,我们一起来利用SKAction的来为熊猫创建动画,我们将学会通过纹理组产生动画,使用永远循环的SKAction让熊猫不停的跑动. 要点: 枚举的使用:用来记录熊猫的动作状态 enum Sta ...

  5. Summary: Merge Sort of Array && 求逆序对

    常用算法(后面有inplace版本): package ArrayMergeSort; import java.util.Arrays; public class Solution { public ...

  6. For嵌套输出图形

    /*输出此图形    *   * *  * * * * * * ** * * * *  * * * *   * * *   * *     *解析:可以把此图形看成两部分----*---* *--* ...

  7. Codeforce Round #215 Div2 C

    还以为就这么点分了,不会跪了,起码有点加,生活都这么艰难了,为什么不让我好好地活下去! 是不是世界对我充满了恶意! 当然还是自己太菜! B题没初始化第一个就杯具了一次 C题大概的弄出来了,调了半个小时 ...

  8. php-wamp滴定仪网站的根目录

    1.点击wamp中的Apache中的httpd.conf:如下图修改两处 2.进入wamp的安装目录下:修改这两个文件(目的:修改wamp中网站目录) 内容如下图: 关闭wamp服务:重启wamp

  9. Android 5.0新特性了解(二)----RippleEffect

    1.本文介绍的是Android5.0中其中一个炫酷的效果,点击水波纹扩散效果( RippleEffect),以下介绍的实现方式都是调用Android5.0的新API,并非自定义实现,所以支持在Andr ...

  10. 夺命雷公狗-----tp中遇到数据乘积的问题的遇见

    昨晚遇到了一个很神奇的问题, 然后打印出来的结果是 ) LIMIT , 然后dump出来的结果有点无语,他是10*10这样的倍增的,如果数据量大,分分钟直接可以让服务器直接死掉.... 想这问题我想了 ...