MySQL——单行函数和分组函数

2023.9.3

单行函数的SQL语句学习笔记如下:

sql 复制代码
#常见单行函数介绍(部分省略)
#字符函数
#将姓变大写,名变小写,然后拼接。
SELECT CONCAT(UPPER(`last_name`),' ',LOWER(`first_name`)) AS 姓名 FROM `employees`;
# 姓名中首字符大写,其他字符小写然后用_拼接,显示出来
SELECT CONCAT(UPPER(SUBSTR(`last_name`,1,1)),'_',LOWER(SUBSTR(`last_name`,2))) AS 姓名 FROM `employees`;
#查询员工的工资,要求部门号=30,显示的工资为1.1倍 部门号=40,显示的工资为1.2倍 部门号=50,显示的工资为1.3倍 其他部门,显示的工资为原工资
SELECT salary AS 原工资,`department_id`,
CASE `department_id` WHEN 30 THEN salary*1.1 WHEN 40 THEN salary*1.2 WHEN 50 THEN salary*1.3 ELSE salary END AS 新工资 FROM `employees`;
##案例:查询员工的工资的情况 如果工资>20000,显示A级别 如果工资>15000,显示B级别 如果工资>10000,显示c级别 否则,显示D级别
SELECT salary, 
CASE
WHEN salary>20000 THEN 'A'
WHEN salary>15000 THEN 'B'
WHEN salary>10000 THEN 'C'
ELSE 'D'
END AS 工资级别
FROM `employees`;

常见函数测试题:

sql 复制代码
SELECT NOW();
SELECT `employee_id`,`last_name`,`salary`,`salary`*1.2 AS 'new salary' FROM `employees`;
SELECT LENGTH(`last_name`) AS 长度,SUBSTR(`last_name`,1,1) AS 首字母,`last_name` FROM `employees` ORDER BY 首字母;
SELECT CONCAT(`last_name`,' earns ',salary,' monthly but wants ',salary*3) AS 'dream salary' FROM `employees` WHERE salary=24000;
SELECT `last_name`,`job_id`,
CASE `job_id` 
WHEN 'AD_PRES' THEN 'A'
WHEN 'ST_MAN' 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';

分组函数的SQL学习笔记:

sql 复制代码
#常见分组函数介绍
#功能:用作统计使用,又称为聚合函数或统计函数或组函数
SELECT SUM(salary) FROM `employees`;
SELECT AVG(salary) FROM `employees`;
SELECT MAX(salary) FROM `employees`;
SELECT MIN(salary) FROM `employees`;
SELECT COUNT(salary) FROM `employees`;
SELECT SUM(salary) AS 薪资和,ROUND(AVG(salary),2) AS 平均薪资 FROM `employees`;
SELECT MAX(`last_name`),MIN(`last_name`) FROM `employees`;
SELECT SUM(`commission_pct`),AVG(`commission_pct`) FROM `employees`;#分组函数会忽略null值。
SELECT COUNT(DISTINCT salary),COUNT(salary) FROM `employees`; #搭配distinct使用
SELECT COUNT(*) FROM `employees`;
SELECT COUNT(1) FROM `employees`;#同上

分组函数测试题:

1、查询公司员工工资的最大值,最小值,平均值,总和

2、查询员工表中的最大入职时间和最小入职时间的相差天数(DIFFRENCE)查询都门编号为90的员工个数

3、查询部门编号为90的员工个数

sql 复制代码
# 分组函数测试题
SELECT MAX(salary),MIN(salary),ROUND(AVG(salary),2),SUM(salary) FROM `employees`;
SELECT DATEDIFF(MAX(`hiredate`),MIN(`hiredate`)) FROM `employees`;
SELECT COUNT(*) AS 个数 FROM `employees` WHERE `department_id`=90;
相关推荐
爬山算法17 分钟前
Redis(69)Redis分布式锁的优点和缺点是什么?
数据库·redis·分布式
RestCloud21 分钟前
从数据库到价值:ETL 工具如何打通南大通用数据库与企业应用
数据库
惜月_treasure1 小时前
Text2SQL与工作流实现:让数据库查询变得轻松又高效
数据库·人工智能·python
-睡到自然醒~1 小时前
[go 面试] 并发与数据一致性:事务的保障
数据库·面试·golang
为乐ovo1 小时前
19.DCL-用户管理
数据库
可观测性用观测云1 小时前
阿里云 RDS MySQL 可观测性最佳实践
mysql
一个天蝎座 白勺 程序猿1 小时前
金仓数据库KingbaseES实现MongoDB平滑迁移全攻略:从架构适配到性能调优的完整实践
数据库·mongodb·数据迁移·kingbasees·金仓数据库
武子康1 小时前
Java-153 深入浅出 MongoDB 全面的适用场景分析与选型指南 场景应用指南
java·开发语言·数据库·mongodb·性能优化·系统架构·nosql
2401_837088502 小时前
Redis通用命令
数据库·redis·缓存
程序边界2 小时前
MongoDB迁移到KES实战全纪录(上):迁移准备与实施指南
数据库·mongodb