MySQL的常见函数

MySQL的常见函数

常见函数的分类: 字符函数,数学函数,日期函数,控制流程函数。
,字符函数
在这里插入图片描述

1.length() 获取参数值的字节数

SELECT LENGTH(last_name) FROM employees;
//中文字符占三个字节

2.concat() 拼接字符串

SELECT CONCAT(last_name,first_name) 姓名 FROM employees;

3.substr() 截取参数值的字节

//在MySQL中索引从1开始
截取从指定的索引处后的所有字符
SELECT SUBSTR('我是一个程序员',5);//结果为 程序员

从指定的索引后截取指定的字符长度的字符
SELECT SUBSTR('我是一个小白',3,4);//结果为一个小白

4.instr() 返回字符串第一次出现的索引,如果找不到就返回0

SELECT INSTR('谁是凶手','凶');//返回的索引为3

5 .trim() 去重

SELECT TRIM('    快乐      ');//将前后的空格除去
SELECT TRIM('a' FROM 'aaaaa快乐aaaaa');//将前后的a都去除

6 .lpad(),rpad()用指定的字符实现左右填充指定的长度

SELECT LPAD('小狗包弟',5,'*');//结果为*小狗包弟
SELECT RPAD('小狗包弟',6,'%');//结果为小狗包弟%%
SELECT RPAD('小狗包弟',2,'%');//结果为小狗
当指定长度小于参数的字符长度,就是截取参数的字符

7 .replace() 替换字符

SELECT REPLACE('abcd','a','g');//结果为gbcd

8.upper(),lower() 将传入的字符全部大写或小写

SELECT LOWER('GZKL');//结果为gzkl
SELECT UPPER('zyyxx');//结果为ZYYXX

二,数字函数
1,round() 小数点四舍五入

SELECT ROUND(1.4); //结果为1
SELECT ROUND(1.6); //结果为2

2,truncate() 取小数点后几位数

SELECT TRUNCATE(3.1425926,2);//结果为3.14

3,rod()取余数

SELECT MOD(111,11);结果为1

三,日期函数

1.now() 获取当前系统的时间日期

SELECT NOW();//结果为 2017-7-21 11.21.22

2,curtime() curdate() 获取当前系统的时间,日期

SELECT CURTIME();//11.43.33
SELECT CURDATE();//2020-7-21

3,str_to_date() 将日期格式的字符串转换为指定格式的日期

SELECT STR_TO_DATE('3-4-2020','%d-%m-%Y');//2020-04-03

4,date_format() 将日期转换为字符

SELECT DATE_FORMAT(CURDATE(),'%y-%c-%d');//将当前系统日期转换为字符

日期的格式符
在这里插入图片描述

三,控制流程函数
1,if函数:if else的效果

SELECT IF(10>4,'大','小');//当表达式为true时返回大
SELECT IF(10<4,'大','小');//当表达式为false时返回小

2,case表达式:
(1)格式1 这种类似java中的switch case
case 要判断的字段或表达式
when 常量1 then 要显示的值1或表达式1;
when 常量2 then 要显示的值2或表达式2;

else 要显示的值n或者语句n;
end

//用job_id进行划分等级
SELECT last_name AS Last_name,job_id AS Job_id,
CASE  job_id
WHEN 'AD_PRES' THEN 'A' 
WHEN 'ST_MA ' THEN 'B'
WHEN 'IT_PROG'  THEN 'C'
WHEN 'SA_REP' THEN 'D'
WHEN 'ST_CLERK' THEN 'E'
END AS Grade
FROM employees 
WHERE job_id='AD_PRES';

在这里插入图片描述

1)格式2 这种类似java中的if…else if…else
case
when 条件1 then 显示的值1或者表达式1
when 条件2 then 显示的值2或者表达式2

else 要显示的值n或语句n
end

SELECT last_name,
CASE
WHEN salary>5000 THEN '一般'
WHEN salary>10000 THEN '中等'
WHEN salary>15000 THEN '上流'
ELSE '不行'
END AS 等级
FROM employees;

在这里插入图片描述

四,分组函数
分组函数为 max() ,min() , avg() , sum() , count(),
sum(),avg()一般处理数值型,
max(),min()任何类型都可以
count(*)表示统计行数
以上都忽略null值 都可以用distinct去重

SELECT MIN(salary) FROM employees;
SELECT MAX(salary) FROM employees;
SELECT AVG(salary) FROM employees;
SELECT SUM(salary) FROM employees;
SELECT  SUM(DISTINCT salary) FROM employees;
SELECT  COUNT(salary) FROM employees;
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值