MySql(四)函数

字符函数

数字函数

日期函数

DATE_FORMAT() 函数的参数种类格式描述:

%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')

你可能感兴趣的:(MySql(四)函数)