MySQL 常见函数

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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值