MySQL 常见函数
*#1.单行函数
/*
功能:类似于java中的方法
调用:
select 函数名(实参列表) 【from 表】
特点:
1.叫什么(函数名)
2.干什么(函数功能)
分类:
1.单行函数:字符函数,数学函数,日期函数,其他函数,流程控制函数
处理使用
2.分组函数
功能:做统计使用,又称为统计函数,聚合函数,组函数
*/
#1.字符函数
#length() 获取参数值的字节个数
SELECT LENGTH(‘john’);
SELECT LENGTH(‘你好hahaha’);
#char_length() 获得字符数
#查看字符集
SHOW VARIABLES LIKE ‘%char%’;
#2.concat 拼接字符串
SELECT CONCAT(‘a’,’_’,‘b’);
#3.upper()\lower()
SELECT UPPER(‘fdJfd’);
SELECT LOWER(‘fdJfd’);
#4.substr() substring()截取字符
#注意:索引从一开始
#两个参数,从指定索引处开始,截取指定长度的字符
SELECT SUBSTR(‘gjyayq’,3) a;
SELECT SUBSTR(‘gjyayq’,3,1) a;
#5.instr() 返回子串第一次出现的索引,找不到返回0
SELECT INSTR(‘gjyayq’,‘yq’);
#6trim()
SELECT LENGTH (TRIM(’ fds d '));
SELECT TRIM(‘a’ FROM ‘aaaaaaaaaaaFSDSDASAaaaaaaaaaaaaaaaaa’) a;
#7.lpad() 左填充(指定字符,指定长度) rpad() 右填充(指定字符,指定长度)
SELECT LPAD(‘gjyayq’,9,‘a’) a;
SELECT RPAD(‘gjyayq’,9,‘a’) a;
#8.replace()
SELECT REPLACE(‘gjyayq’,‘yq’,‘ccx’) a;
#数学函数
#round 四舍五入
SELECT ROUND(1.32);
SELECT ROUND(1.2343,2);
#ceil 向上取整 floor 向下取整
SELECT CEIL(1.22);
SELECT FLOOR(1.22);
#truncate 截断
SELECT TRUNCATE(1.463,1);
#mod 取余 被除数为正,结果为正
#mod(a,b):a-a/b*b
SELECT MOD(10,-3);
SELECT 10%3;
#日期函数
#now 返回当前系统日期和时间
SELECT NOW();
#curdate 日期 curtime 时间
SELECT CURDATE();
SELECT CURTIME();
#可以获取指定的部分,年,月,日,小时,分,秒。加参数now()
SELECT YEAR();
SELECT MONTHNAME(NOW());
SELECT MONTH();
SELECT DAY();
SELECT HOUR();
SELECT MINUTE();
SELECT SECOND(NOW());
DATEDIFF() 两个日期相差的天数
/*
%Y:四位的年份
%y:2位的年份
%m:月份(01,02。。。11,12)
%c:月份(1,2,3,4。。。11,12)
%d:日
%H:小时(24)
%h:小时(12)
%i:分钟
%s:秒
*/
#str_to_date:将日期格式的字符转换成指定格式的日期
SELECT STR_TO_DATE(‘1998-3-3’,’%Y-%c-%d’);
#date_format:将日期转换为字符
SELECT DATE_FORMAT(NOW(),’%Y年%m月%d日’);
#其他函数
SELECT VERSION();
SELECT DATABASE();
SELECT USER();
流程控制函数
#1.if函数:if else 的效果
SELECT IF(10>5,‘A’,‘B’);
#2.case函数的使用之一:switch case的效果
/*
java:
switch(变量或表达式){
case 常量:语句1;break;
…
case 常量:语句n;break;
}
mysql中
1.
case 要判断的字段或表达式
when 常量1 then 要显示的值(语句;)
…
when 常量2 then 要显示的值(语句;)
else 要显示的值(语句;)
end
2.多重if语句
case
when 条件1 then 要显示的值(语句;)
…
when 条件1 then 要显示的值(语句;)
else 要显示的值(语句;)
end
*/
#案例:按成绩分级别
SELECT score.平均成绩
,
CASE
WHEN score.平均成绩
>=90 THEN ‘A’
WHEN score.平均成绩
>=80 THEN ‘B’
WHEN score.平均成绩
>=70 THEN ‘C’
WHEN score.平均成绩
>=60 THEN ‘D’
ELSE ‘E’
END AS a
FROM score;