【SQL server数据库基础】子查询

SQL server数据库基础——子查询

连接查询和子查询的区别:

​ ① 连接查询可以查询任意一个的表的字段;代价更高

​ ② 子查询只能查询一个表的字段;代价更低

-- 查询图像2001班的学生信息
-- 连接查询
select *
from StudentInfo a join ClassInfo b
on a.ClassInfoID = b.ClassInfoID
where ClassInfoName = '图像2001'

-- 子查询
select * from StudentInfo
where ClassInfoID = (
	select CalssInfoID from dbo.ClassInfo
    where ClassInfoName = '图像2001'
)

1. 子查询用作派生表

在这里插入图片描述

-- 查询比所有课程类别ID为1的课程总学时都要高的课程
select CourseInfoName,CourseTypeID
from dbo.CourseInfo
where CourseInfoHotHrs > all (
	select CourseInfoHotHrs from dbo.CourseInfo
    where CourseTypeID = 1
)

-- 查询所有已获‘副教授’职称的女教师的姓名、性别、学历、专业和职称
select * from (
	select TeachInfoName,TeachInfoSex,TeachInfoKnowl,TeachInfoSpec,TeachInfoTitle
    from dbo.TeachInfo
    where TeachInfoTitle = '副教授'
) as t
where t.TeachInfoSex = '女'

2. 子查询用作表达式

在这里插入图片描述

在这里插入图片描述

-- 查询开设了课程ID为7的课程的教师的相关信息
-- 首先查询课程ID为7的课程有哪些教师授课
select TeachInfoID from dbo.TeachCourse
where CourseInfoID = 7
-- 其次查询上一个步骤里相关老师的信息
select TeachInfoID,TeachInfoName,TeachInfoSex,TeachInfoKnowl,TeachInfoSpec,TeachInfoTitle
from dbo.TeachInfo
where TeachInfoID in (   -- in 做范围判断,= 做单值判断
	select TeachInfoID from dbo.TeachCourse
	where CourseInfoID = 7
)

-- 查询选修了7号课程的学生学号、姓名和电话
select StdInfoNum,StdInfoName,StdInfoTel
from dbo.StudentInfo
where exists (
    -- 查询选了课的学生学号
	select * from dbo.StudentCourse
    where StdInfoID = dbo.StudentInfo.StdInfoID
    and exists (
        -- 先查询教授7号课程的教师
    	select * from dbo.TeachCourse
        where CourseInfoID = 7
        -- 并且教师课程号等于学生选课表里的教师课程号,表示:有教师教授的课才选,剔除没有教师教授的课
        and TeachCourseID = dbo.StudentCourse.TeachCourseID
    )
)

-- 查询与“刘立”同班同学的信息
select * from dbo.StudentInfo
where ClassInfoID = (
	select ClassInfoID from dbo.StudentInfo
    where StdInfoName = '刘立'
)

-- 查询课程考试不及格的学生的姓名、性别
select StdInfoName,StdInfoSex
from dbo.StudentInfo
where StdInfoID in (
	select StdInfoID from dbo.StudentCourse
    where StudCourseUsuGrd < 60
)

-- 查询课程考试不及格的学生的姓名和课程名
select 姓名 = (  
	select StdInfoName from dbo.StudentInfo
    where StdInfoID = a.StdInfoID  -- 限定有课程的学生
),
课程名 = (
	select CourseInfoID from dbo.TeachCourse
    where CourseInfoID in (
    	select CourseInfoID from dbo.TeachCourse
        where TeachCourseID = a.TeachCourseID
    )
)
from dbo.StudentCourse a
where StudCourseUsuGrd < 60
-- 用连接查询
select StdInfoName,CourseInfoName,StudCourseUsuGrd
from dbo.CourseInfo a join dbo.TeachCourse b
on a.CourseInfoID = b.CourseInfoID join dbo.StudentCourse c
on b.TeachCourseID = c.TeachCourseID join dbo.StudentInfo d
on c.StdInfoID = d.StdInfoID
where StudCourseUsuGrd < 60

-- 查询网页设计课程不及格的学生姓名、性别和联系电话
select StdInfoName,StdInfoSex,StdInfoTel
from dbo.StudentInfo
where StdInfoID in (
	select StdInfoID from dbo.StudentCourse
    where StudCourseID in (
    	select TeachCourseID from dbo.TeachCourse
        where CourseInfoID = (
        	select CourseInfoID from dbo.CourseInfo
			where CourseInfoName = '网页设计'
        )
    )
)

主文章:备考计算机三级数据库——SQL 案例

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

iFulling

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值