sql 五十题 26-30

sql 复制代码
#26、查询每门课程被选修的学生数 
select
count(a.s_id) as count_course , b.c_name
from
score a
left join 
course b
on
a.c_id = b.c_id
group by a.c_id

书写怎么这么糟糕......


sql 复制代码
 #27、查询出只有两门课程的全部学生的学号和姓名
 select count(a.c_id),b.*
 from score a, student b
 where a.s_id = b.s_id
 group by a.s_id
 having count(a.c_id) = 2

sql 复制代码
#查询男生女生人数
select
count(s_sex),s_sex
from
student
group by s_sex

666count总是搞不懂应该count谁,用谁分类。


sql 复制代码
-- 29、查询名字中含有"风"字的学生信息
select
*
from
student
where s_name like '%风'

注意like 和 = 的区别


sql 复制代码
-- 30、查询同名同性学生名单,并统计同名人数
with t_table as 
	(select count(s_name) over (partition by s_id order by count(s_name)) as count_name,
		s_name,
		s_id,
		s_sex
	from student 
	group by s_id )
select s_name,s_sex,count(*)
from
t_table
where count_name > 1
group by s_id

明显你写的很复杂,看解析

sql 复制代码
select
	a.s_name,
    a.s_sex,
    count(*) 
from student a 
JOIN 
	student b 
on a.s_id !=b.s_id 
and a.s_name = b.s_name 
and a.s_sex = b.s_sex
GROUP BY a.s_name,a.s_sex

首先两个表连接做笛卡尔积,随后限定条件有【a.s_id != b.s_id】这个条件出来就是异响匹配,你写的时候没想到,然后是两个连接条件,再是【count(*)】是计算做出来的表格所有的行数,也就是只符合条件的总人数。

相关推荐
倔强的石头_9 小时前
《Kingbase护城河》——猎捕慢查询:执行计划的微观解析与索引调优实战
数据库
SelectDB11 小时前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
jiayou642 天前
KingbaseES 表级与列级加密完全指南
数据库·后端
GBASE2 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr3 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
唐青枫4 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
吃糖的小孩4 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3505 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3505 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3505 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库