①NOW():返回当前系统的日期和时间
SELECT NOW();
②CURDATE():返回当前系统日期,不包含时间
SELECT CURDATE();
③CURTIME():返回当前系统时间,不包括日期
SELECT CURTIME();
⑦YREAR()
:获取指定日期字段的年
SELECT YEAR(NOW());
SELECT YEAR('2021-09-30') AS result;
⑧MONTH()
:获取指定日期字段的月,MONTHNAME()
则可以返回月份英文
SELECT MONTH('2021-09-30') AS result;
SELECT MONTHNAME('2021-09-30') AS result;
日,小时,分钟,秒钟都可以同上
⑨STR_TO_DATE()
:将字符按照指定的格式转为日期
#相当于是解析:两个参数格式要匹配 SELECT STR_TO_DATE('9-30 2021','%m-%d %Y') AS result;
⑩DATE_FORMAT()
:将日期转换成字符
#相当于是格式化 SELECT DATE_FORMAT(NOW(),'%Y年%m月%d日') AS result;
四、其他函数
#查看版本 SELECT VERSION(); #查看数据库 SELECT DATABASE(); #查看用户 SELECT USER();
五、流程控制函数
①IF()
:判断,第一个参数是条件,第二个是true的返回,第三个是false的返回
SELECT IF(10>5,'大','小') AS result;
②CASE()
使用一:类似于Java中switch
CASE 要判断的 WHEN 常量1 THEN 语句1;或者要显示的值1 ... ELSE 语句;或者要显示的值 END
示例
#示例为要显示的值,不加‘;' SELECT `last_name`,`salary`,`department_id`, CASE `department_id` WHEN 100 THEN `salary`*(1+0.8) WHEN 90 THEN `salary`*(1+0.6) WHEN 80 THEN `salary`*(1+0.4) WHEN 70 THEN `salary`*(1+0.2) ELSE `salary` END AS 最终工资 FROM employees;
③CASE()
使用一:类似于Java中多重if
CASE WHEN 条件1 THEN SELECT 语句1;或者要显示的值1 ... ELSE 语句;或者要显示的值 END
示例
#示例为要显示的值,不加‘;' SELECT `last_name`,`salary`, CASE WHEN `salary`>20000 THEN 'A级别' WHEN `salary`>15000 THEN 'B级别' WHEN `salary`>10000 THEN 'C级别' ELSE 'D级别' END AS 等级 FROM employees;
到此这篇关于MySQL深度精讲单行函数以及字符数学日期流程控制的文章就介绍到这了,更多相关MySQL 单行函数 内容请搜索
更多Mysql内容来自木庄网络博客
标签:Mysql
相关阅读 >>
更多相关阅读请进入《mysql》频道 >>

数据库系统概念 第6版
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。