- DELIMITER $$
第一句是定义一个结束标识符,因为MySQL默认是以分号作为SQL语句的结束符的,而函数体内部要用到分号,所以会跟默认的SQL结束符发生冲突,所以需要先定义一个其他的符号作为SQL的结束符;
create function name_of_function()
RETURNS INT
begin
DECLARE j INT;
SET j = 0;
RETURN j;
end$$
select name_of_functionw---->函数名
语法:
新建:
Create function function_name(参数列表)returns返回值类型
函数体
函数名,应该合法的标识符,并且不应该与已有的关键字冲突。
一个函数应该属于某个数据库,可以使用db_name.funciton_name的形式执行当前函数所属数据库,否则为当前数据库。
参数部分,由参数名和参数类型组成。
返回值类类型
函数体由多条可用的mysql语句,流程控制,变量声明等语句构成。
多条语句应该使用begin end语句块包含。
注意,一定要有return返回值语句。
删除:
Dropfunction if existsfunction_name;
查看:
Show function status like ‘partten’
Show create functionfunction_name;
修改:
Alter functionfunction_name函数选项。
create function name_of_functionone()
RETURNS INT
begin
RETURN (select id from user where id=1);
end$$
//-----------------------------------------------
create function name_of_functionone()
RETURNS varchar(255)
begin
RETURN (select name from user where id=1);
end$$