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

相关推荐
互联网哪些事情3 小时前
服务器防御 SQL 注入
运维·服务器·sql·sql注入主机
小尧嵌入式3 小时前
QT软件开发知识点流程及记事本开发
服务器·开发语言·数据库·c++·qt
子夜江寒3 小时前
SQL 从基础操作到高级查询
数据库·sql
Dxy12393102163 小时前
MySQL快速入门
数据库·mysql
NaiLuo_453 小时前
MySQL表的约束
数据库·sql·mysql
kkkkkkkkl243 小时前
彻底讲清 MySQL InnoDB 锁机制:从 Record 到 Next-Key 的全景理解
数据库·mysql
DBA小马哥3 小时前
Oracle迁移中查询优化器原理解析与实战优化策略
数据库·oracle
gugugu.3 小时前
Redis Hash类型深度解析:结构、原理与实战应用
数据库·redis·哈希算法
卓码软件测评3 小时前
第三方数据库测试:【utPLSQL用于Oracle和tSQLt用于SQL Server数据库单元测试框架入门】
数据库·oracle·sqlserver·单元测试·mssql