SQL_查询语句

表的数据


Case1. 计算每个文件的平均size,并只显示平均size超过30000000:

sql 复制代码
select
	rfi.file_name,
	avg(rfi.file_size)
from
	raw_file_info rfi
group by
	rfi.file_name
having
	avg(rfi.file_size)>30000000;
解析

这个查询使用了 GROUP BY 子句进行分组,AVG () 函数计算平均值,HAVING 子句用于过滤分组后的结果。

Case2. 查询表中每个文件size最大的:

sql 复制代码
select
	rf.file_name ,rf.file_size 
from
	raw_file_info rf
join (
	select
		file_name,
		max(file_size) as max_size
	from
		raw_file_info
	group by
		file_name ) as mf on
	rf.file_name = mf.file_name and rf.file_size =mf.max_size
解析

通过子查询找出每个文件size最大的

使用外层查询关联的文件名

Case3.找出size高于平均size的所有文件:

sql 复制代码
select
	*
from
	raw_file_info rfi
where
	rfi.file_size >(
	select
		avg(rf.file_size)
	from
		raw_file_info rf);
解析

这个查询使用了子查询来计算平均size,然后在主查询中使用这个结果进行比较。

Case4. 查询表中所有重复的文件名称及其出现次数

sql 复制代码
select
	rfi.file_name,
	count(*)
from
	raw_file_info rfi
group by
	rfi.file_name
having
	count(*)>1; 
解析

使用 GROUP BY 对名字分组。

HAVING 子句筛选分组后的数据。

考查聚合和过滤的结合使用。

Case5. 查询排名(降序排列)

sql 复制代码
select
	rfi.file_name ,
	rfi.file_size ,
	rank() over(
	order by rfi.file_name desc,
	rfi.file_size desc) as rank
from
	raw_file_info rfi ;
解析

使用窗口函数 RANK() 实现排名。

考查窗口函数的使用。

Case6. 对于每个文件,查找size排名前十的文件

sql 复制代码
select
	*
from
	(
	select
		rfi.file_name ,
		rfi.file_size ,
		row_number() over(
	order by
		rfi.file_size desc) as rank
	from
		raw_file_info rfi) t
where
	t.rank <= 10;
解析

这个查询使用了窗口函数 DENSE_RANK () 来为每个文件根据size进行排名,然后在外部查询中筛选出排名前十的记录。

相关推荐
不辉放弃2 小时前
SQL 主键(Primary Key)
数据库·sql·oracle
画扇落汗3 小时前
Python 几种将数据插入到数据库的方法(单行插入、批量插入,SQL Server、MySQL,insert into)
数据库·python·sql·mysql
Full Stack Developme4 小时前
SQL 查询中使用 IN 导致性能问题的解决方法
数据库·sql
XiaoLeisj5 小时前
【图书管理系统】深入解析基于 MyBatis 数据持久化操作:全栈开发图书管理系统:查询图书属性接口(注解实现)、修改图书属性接口(XML 实现)
xml·java·数据库·spring boot·sql·java-ee·mybatis
Gauss松鼠会7 小时前
GaussDB回调机制深度实践:从事件驱动到系统集成
开发语言·javascript·数据库·sql·gaussdb
狂奔solar14 小时前
Vanna + qwq32b 实现 text2SQL
数据库·sql
OceanBase数据库官方博客18 小时前
火山模型的优缺点与优化实践 | OceanBase SQL优化
sql·oceanbase·分布式数据库
Dav_20991 天前
dav_1_MySQL数据库排查cpu消耗高的sql
数据库·sql·mysql
小诸葛的博客1 天前
Go 语言中的select是做什么的
数据库·sql·golang