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(*)】是计算做出来的表格所有的行数,也就是只符合条件的总人数。

相关推荐
IvorySQL8 分钟前
PostgreSQL 19 重磅新语法终于补齐这个缺口
数据库·postgresql·开源
IvorySQL15 分钟前
PostgreSQL 技术日报 (3月23日)|使用 rdtsc 减少 EXPLAIN ANALYZE 的计时开销
数据库·postgresql·开源
yhole27 分钟前
SQL中的REGEXP正则表达式使用指南
数据库·sql·正则表达式
IvorySQL32 分钟前
PostgreSQL 技术日报 (3月21日)|这些机制,可能并非 “ 理所当然 ”
数据库·postgresql·开源
m0_5180194841 分钟前
使用Seaborn绘制统计图形:更美更简单
jvm·数据库·python
卓怡学长1 小时前
m280本科生导师指导平台
java·数据库·spring·tomcat·maven·intellij-idea
大尚来也1 小时前
Serverless架构深度解析:适用场景、核心局限与破局之道
数据库
Wave8451 小时前
非阻塞按键(单击,双击,长按)
数据库
2401_831824961 小时前
为你的Python脚本添加图形界面(GUI)
jvm·数据库·python
久违的太阳1 小时前
记录一次ORACLE RAC安装PSU补丁步骤
数据库·oracle