语法:

新建:

Create function function_name(參数列表)returns返回值类型

函数体

函数名,应该合法的标识符,而且不应该与已有的keyword冲突。

一个函数应该属于某个数据库,能够使用db_name.funciton_name的形式运行当前函数所属数据库,否则为当前数据库。

參数部分,由參数名和參数类型组成。

返回值类类型

函数体由多条可用的mysql语句,流程控制,变量声明等语句构成。

多条语句应该使用begin end语句块包括。

注意,一定要有return返回值语句。

删除:

Dropfunction if existsfunction_name;

查看:

Show function status like ‘partten’

Show create functionfunction_name;

改动:

Alter functionfunction_name函数选项。

样例:

Hello world!

IF语句

IF search_conditionTHEN

statement_list

[ELSEIF search_conditionTHENstatement_list]

...

[ELSE statement_list]ENDIF;

CASE语句

CASE case_value

WHEN when_valueTHENstatement_list

[WHEN when_value THENstatement_list]

...

[ELSE statement_list]

END CASE;

循环:

While

[begin_label:]WHILEsearch_conditionDO

statement_list

END WHILE [end_label];

假设须要在循环内提前终止 while循环,则须要使用标签;标签须要成对出现。

退出循环

退出整个循环leave         相当于break

退出当前循环iterate         相当于 continue

通过退出的标签决定退出哪个循环。

变量声明:
语法:
DECLARE var_name[,...] type [DEFAULT value] 
这个语句被用来声明局部变量。要给变量提供一个默认值,请包括一个DEFAULT子句。值能够被指定为一个表达式,不须要为一个常数。假设没有DEFAULT子句,初始值为NULL。 
使用
语序使用 set 和 select into语句为变量赋值。

注意在函数内是能够使用全局变量(用户自己定义的变量的)@XXX   全局变量不用声明 能够直接@XXX使用。

样例:获取当前班级内,最大的学号。

參考学生表

create table join_student(

stu_id int not null auto_increment,

stu_no char(10),

class_id int not null,

stu_name varchar(10),

stu_info text,

primary key (stu_id)

);

计算新增学号

drop function if existssno;

delimiter $$             #在包括有语句块时  能够更换语句结束符“;”  为“$$”

create function sno(c_id int)returns char(10)

begin

declare last_no char(10);    #声明一个局部变量  用来保存当前最大的学号, 假设没有就为null

declare class_name char(10);

select stu_no from join_student where class_id=c_id order by stu_no desc limit 1 into last_no;

if last_no is null then      #假设为空代表当前班级没有学生   从1開始,获得班级名字

return concat ((select c_name from join_class where id=c_id into class_name),'001');     #concat() 函数的作用是连接字符串。

else

return concat(left(last_no,7),lpad(right(last_no,3) + 1, 3, '0'));

end if;

#return @last_no;

end

$$

delimiter ;

随机获得学生名字。

drop function if exists sname;

delimiter $$

create function sname() returns char(2)

begin

declare first_name char(16) default '赵钱孙李周吴郑王冯陈褚卫蒋沈韩杨';

declare last_name char(10) default '甲乙丙丁戊己庚辛壬癸';

declare full_name char(2);

set full_name=concat(substring(first_name,floor(rand()*16+1), 1), substring(last_name,floor(rand()*10+1), 1));

return full_name;

end

$$

delimiter ;

========================================================================================

mysql经常使用内置函数

数值函数

Abs(X),绝对值abs(-10.9) = 10

Format(X,D),格式化千分位数值format(1234567.456, 2) =1,234,567.46

Ceil(X),向上取整ceil(10.1) = 11

Floor(X),向下取整floor (10.1) = 10

Round(X),四舍五入去整

Mod(M,N) M%N M MOD N 求余 10%3=1

Pi(),获得圆周率

Pow(M,N) M^N

Sqrt(X),算术平方根

Rand(),随机数

TRUNCATE(X,D) 截取D位小数

时间日期函数

Now(),current_timestamp(); 当前日期时间

Current_date();当前日期

current_time();当前时间

Date(‘yyyy-mm-dd HH;ii:ss’);获取日期部分

Time(‘yyyy-mm-dd HH;ii:ss’);获取时间部分

Date_format(‘yyyy-mm-dd HH;ii:ss’,’%D %y %a %d %m %b %j');

Unix_timestamp();获得unix时间戳

From_unixtime();//从时间戳获得时间

字符串函数

LENGTH(string )   //string长度,字节

CHAR_LENGTH(string)    //string的字符个数

SUBSTRING(str ,position [,length ])   //从str的position開始,取length个字符

REPLACE(str ,search_str ,replace_str)   //在str中用replace_str替换search_str

INSTR(string ,substring )   //返回substring首次在string中出现的位置

CONCAT(string [,... ])   //连接字串

CHARSET(str)  //返回字串字符集

LCASE(string )  //转换成小写

LEFT(string ,length )   //从string2中的左边起取length个字符

LOAD_FILE(file_name)   //从文件读取内容

LOCATE(substring , string [,start_position ])   //同INSTR,但可指定開始位置

LPAD(string ,length ,pad )   //反复用pad加在string开头,直到字串长度为length

LTRIM(string )  //去除前端空格

REPEAT(string ,count )   //反复count次

RPAD(string ,length ,pad)   //在str后用pad补充,直到长度为length

RTRIM(string )   //去除后端空格

STRCMP(string1 ,string2 )   //逐字符比較两字串大小

流程函数:

CASE WHEN [condition]THEN result[WHEN [condition]THEN result ...][ELSE result]END   多分支

IF(expr1,expr2,expr3)  双分支。

聚合函数

Count()

Sum();

Max();

Min();

Avg();

Group_concat()

其它经常使用函数

Md5();

Default();

mysql中自己定义函数编程相关推荐

  1. MySQL中如何定义外键[转]

    MySQL中如何定义外键 假如某个电脑生产商,它的数据库中保存着整机和配件的产品信息.用来保存整机产品信息的表叫做pc:用来保存配件供货信息的表叫做parts. 在pc表中有一个字段,用来描述这款电脑 ...

  2. mysql中数据定义和数据控制语言_MySQL 数据定义语言(DDL)

    SQL 包含以下 4部分:1数据定义语言(DDL):DROP.CREATE.ALTER 等语句.2数据操作语言(DML):INSERT(插入).UPDATE(修改).DELETE(删除)语句.3数据查 ...

  3. mysql中数据定义语言_SQL数据定义语言(DDL)

    数据库模式定义语言DDL(DataDefinition Language),是用于描述数据库中要存储的现实世界实体的语言.一个数据库模式包含该数据库中所有实体的描述定义.这些定义包括结构定义.操作方法 ...

  4. mysql中数据定义和数据控制语言_MySQL的DDL数据定义语言和DCL数据控制语言

    SQL客户端slient内置命令 db01 [world]>help \c 类似于ctrl+c,结束上一条命令 \G 格式化输出,一般针对列特别多的场景使用 exit(\q) 退出当前会话 so ...

  5. MySQL中如何定义一个自己写的函数

    文章目录 数据库中的函数 创建自定义函数 修改自定义函数 删除自定义的函数 在MySQL中存储着一系列的SQL语句,调用函数就是一次性执行这些语句.所以函数可以降低语句的重复. 但要注意到函数是注重返 ...

  6. mysql中数据定义和数据控制语言_DB-数据操控与定义语言

    数据操控语言 数据操控语言主要用于对表中数据的增删改.使用insert可对表进行插入数据,update可修改表中的数据或结构,delete则可进行删除. 首先看一下我们在何表中操作: 1,insert ...

  7. 在Mysql中为什么定义varchar(255)?

    在4.0版本以下,varchar(255)指的是255个字节,使用1个字节存储长度即可.当大于等于256时,要使用2个字节存储长度.所以定义varchar(255)比varchar(256)更好. 但 ...

  8. mysql中存储过程定义

    转载于:https://www.cnblogs.com/han-guang-xue/p/10005761.html

  9. php mysql变量赋值给变量_MySQL_mysql 存储过程中变量的定义与赋值操作,一、变量的定义 mysql中变量定 - phpStudy...

    mysql 存储过程中变量的定义与赋值操作 一.变量的定义mysql中变量定义用declare来定义一局部变量,该变量的使用范围只能在begin...end 块中使用,变量必须定义在复合语句的开头,并 ...

最新文章

  1. 两个函数式解决大数相加的方法
  2. Java Excel表格数据的导入导出
  3. 插入排序c语言_玩扑克牌中插扑克牌手法就是不一样,C语言经典算法之插入排序...
  4. 防爆计算机最新报价,防爆计算机 工厂直销 价格优惠升级方便外形轻巧KJD127防爆计算机...
  5. 是否finally块总是用Java执行?
  6. 【前端统计图】echarts实现属性修改
  7. Deep Learning(深度学习)学习笔记整理系列 一
  8. 第八天2017/04/17(3、C++的几个语法)
  9. androidid什么时候会变_今天是“三九”为什么老话说:三九冰上走一走,过年也能露一手!...
  10. 第3章 Python的数据结构、函数和文件
  11. NVIDIA各个领域芯片现阶段的性能和适应范围
  12. 20165306 我期望的师生关系
  13. 线性代数第九版pdf英文_斯坦福CS229机器学习课程的数学基础(线性代数)翻译完成...
  14. uri=/struts-tags 出错
  15. 2020-02-09 改udev硬件配置策略,改ETHTOOL_OPTS 或改 `/etc/NetworkManager/dispatcher.d/20-ethtool`...
  16. oracle sysman 不存在_Oracle数据库中SYS、SYSTEM、DBSNMP、SYSMAN四用户的区别
  17. 计算机专业英语课程内容,《计算机专业英语》课程教学大纲
  18. Swift 雷达动画
  19. app兼容性测试方案
  20. 股票的最新和历史股息收益率查询(1)

热门文章

  1. 谁是真正的深度学习?英特尔高管与AI大神再“论剑”
  2. 如何检查你的项目是不是真的需要用到 AI?
  3. 做 AI 大咖在顶级单位之间随兴漂移,好开心!
  4. 盘点丨机器学习做不到14件事,你知道吗?
  5. 深度丨解密Python为什么能够风靡全宇宙
  6. 神经网络早期的感知机模型
  7. 死前真的会有「跑马灯」,人类首次同步测量大脑濒死状态
  8. 为什么数学家、统计学家和机器学习专家会用不同方式解决问题?
  9. 谷歌时间晶体登上Nature,诺奖得主重大猜想成为现实
  10. 周鸿祎:过去只能在虚拟世界里发起的网络攻击,现在都可以通过物联网直达生产一线...