字符函数
数字函数
日期函数
%a 缩写星期名
%b 缩写月名
%c 月,数值
%D 带有英文前缀的月中的天
%d 月的天,数值(00-31)
%e 月的天,数值(0-31)
%f 微秒
%H 小时 (00-23)
%h 小时 (01-12)
%I 小时 (01-12)
%i 分钟,数值(00-59)
%j 年的天 (001-366)
%k 小时 (0-23)
%l 小时 (1-12)''
%M 月名
%m 月,数值(00-12)
%p AM 或 PM
%r 时间,12-小时(hh:mm:ss AM 或 PM)
%S 秒(00-59)
%s 秒(00-59)
%T 时间, 24-小时 (hh:mm:ss)
%U 周 (00-53) 星期日是一周的第一天
%u 周 (00-53) 星期一是一周的第一天
%V 周 (01-53) 星期日是一周的第一天,与 %X 使用
%v 周 (01-53) 星期一是一周的第一天,与 %x 使用
%W 星期名
%w 周的天 (0=星期日%E, 6=星期六)
%X 年,其中的星期日是周的第一天,4 位,与 %V 使用
%x 年,其中的星期一是周的第一天,4 位,与 %v 使用
%Y 年,4 位
%y 年,2 位
控制流函数
-------------示例----------
-------------------------------字符函数-----------------------------------
#在hello的左右两边各添加5个’*’,返回‘*****hello*****’(三种方法实现)
SELECT RPAD(LPAD('hello',10,'*'),15,'*');
SELECT CONCAT(CONCAT('*****','hello'),'*****');
SELECT RPAD(CONCAT('*****','hello'),15,'*');
SELECT CONCAT(LPAD('hello',10,'*'),'*****');
#从字符串‘abcdefghijklmn’中返回后三位字符,并转换为大写
SELECT UPPER(RIGHT('abcdefghijklmn',3))
#查询名字包含5个字符的员工的姓名,工资,奖金(奖金为空则显示为0)、职位、部门号
SELECT ename,sal,IFNULL(comm,0) comm,job,deptno FROM emp
WHERE LENGTH(ename) >= 5
#查询姓名中不含‘A’的员工的编号、姓名、职位、部门号
SELECT empno,ename,job,deptno FROM emp
WHERE INSTR(ename,'A') = 0
#显示将员工姓名的第一个字符去掉后的字符串,如‘ALLEN’显示为‘LLEN’
SELECT ename FROM emp #xianshizhiqiandemingzi
SELECT SUBSTRING(ename,2,LENGTH(ename)-1) FROM emp
#使用员工姓名的第一个字符,从左边将员工姓名补齐到长度为10
SELECT LPAD(ename,10,LEFT(ename,1)) FROM emp
-------------------------------日期函数-----------------------------------
#查询6月份入职的员工的姓名,工资,入职日期、职位、部门号
SELECT ename,sal,hiredate,job,deptno FROM emp
WHERE DATE_FORMAT(hiredate,'%c') = 6
#查询1981年下半年入职的员工的编号、姓名、职位、入职日期、部门号
SELECT empno,ename,job,hiredate,deptno FROM emp
WHERE DATE_FORMAT(hiredate,'%Y') = 1981
AND DATE_FORMAT(hiredate,'%c')>6
#查询在某个月倒数第三天入职的员工的姓名、职位、入职日期
SELECT ename,job,hiredate FROM emp
WHERE DATE_FORMAT(LAST_DAY(hiredate),'%e')-2 = DATE_FORMAT(hiredate,'%e')