自定义函数
用户自定义函数(user_defined function)是一种对mysql扩展的途径,其用法与内置函数相同.
自定义函数的两个必要条件
(1)参数
(2)返回值
创建自定义函数
Create function function_name returns {string|integer|real|decimal} routine_body
Routine_body:函数体
(1)函数体由合法的sql语法构成
(2)函数体可以是简单的select或insert语句
(3)函数体如果为复合结构则使用begin...end语句
(4)复合结构可以包含声明、循环、控制结构
创建没有参数的函数
create function f1() returns varchar(30)
return date_format(now(),'%Y年%m月%d日 %H点:%i分:%s秒');
创建带参数的函数
CREATE FUNCTION f2(num1 SMALLINT UNSIGNED,num2 SMALLINT UNSIGNED)
RETURNS FLOAT(10,2) UNSIGNED
RETURN(num1+num2)
删除函数:
DROP FUNCTION fun_name;
//创建具有复合结构函数体的自定义函数
修改分隔符:DELEMITER 分隔符
Eg:DELIMITER // / 将分隔符修改为 '//' /
当函数体内需要执行的是多条语句时,要使用BEGIN...END语句
且当编写函数体内容的时候,需要使用 DELIMITER 关键字将分隔符先修改为别的,否则编写语句的时候写到 ';' 的时候会直接执行,导致函数编写失败
删除函数:DROP FUNCTION [IF EXISTS] function_name
*/
Eg:
DELIMITER //
CREATE FUNCTION ADD_USER(p_id SMALLINT,username VARCHAR(20))
RETURNS INT UNSIGNED
BEGIN
INSERT user(p_id,username) VALUES(p_id,username);
RETURN LAST_INSERT_ID();
END