选读SQL经典实例笔记18_Exactly

这篇具有很好参考价值的文章主要介绍了选读SQL经典实例笔记18_Exactly。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

选读SQL经典实例笔记18_Exactly文章来源地址https://www.toymoban.com/news/detail-625234.html

1. 问题9

1.1. 只讲授一门课程的教授

1.2. sql

select p.*
  from professor p,
       teach t
 where p.lname = t.lname
   and p.lname not in (
select t1.lname
  from teach t1,
       teach t2
 where t1.lname = t2.lname
   and t1.cno > t2.cno
)
LNAME      DEPT           SALARY        AGE
---------- ---------- ---------- ----------
POMEL      SCIENCE           500         65

1.3. 找到讲授了两门以上课程的教授

1.4. 找到讲授了至少一门课程但不存在于第一步返回结果集的教授

1.5. DB2

1.6. Oracle

1.7. SQL Server

1.8. 窗口函数COUNT OVER

1.8.1. sql

select lname, dept, salary, age
  from (
select p.lname,p.dept,p.salary,p.age,
       count(*) over (partition by p.lname) as cnt
  from professor p, teach t
 where p.lname = t.lname
       ) x
 where cnt = 1

1.9. PostgreSQL

1.10. MySQL

1.11. 聚合函数COUNT

1.11.1. sql

select p.lname,p.dept,p.salary,p.age
  from professor p, teach t
 where p.lname = t.lname
 group by p.lname,p.dept,p.salary,p.age
having count(*) = 1

1.12. 内连接PROFESSOR表和TEACH表能够确保把不讲授任何课程的教授都排除掉

1.13. PARTITION是动态的、更灵活的GROUP BY

2. 问题10

2.1. 只选修CS112和CS114课程的学生

2.1.1. 只选了这两门,没有选其他课程

2.2. sql

select s.*
  from student s, take t
 where s.sno = t.sno
   and t.cno = 'CS112'
   and t.cno = 'CS114'

2.3. sql

select s1.*
  from student s1,
       take t1,
       take t2
 where s1.sno = t1.sno
   and s1.sno = t2.sno
   and t1.cno = 'CS112'
   and t2.cno = 'CS114'
   and s1.sno not in (
select s2.sno
  from student s2,
       take t3,
       take t4,
       take t5
 where s2.sno = t3.sno
   and s2.sno = t4.sno
   and s2.sno = t5.sno
   and t3.cno > t4.cno
   and t4.cno > t5.cno
)
SNO SNAME      AGE
--- ---------- ---
  3 DOUG        20

2.4. 找到至少选修了3门课程的学生

2.5. 使用TAKE表的自连接找出选修CS112和CS114的学生

2.6. 筛选出选修CS112和CS114,但选修课程数量又不多于两门的学生

2.7. DB2

2.8. Oracle

2.9. SQL Server

2.10. 窗口函数COUNT OVER和CASE表达式

2.10.1. sql

select sno,sname,age
  from (
select s.sno,
       s.sname,
       s.age,
       count(*) over (partition by s.sno) as cnt,
       sum(case when t.cno in ( 'CS112', 'CS114' )
                then 1 else 0
           end)
       over (partition by s.sno) as both,
       row_number()
       over (partition by s.sno order by s.sno) as rn
  from student s, take t
 where s.sno = t.sno
       ) x
 where cnt = 2
   and both = 2
   and rn = 1

2.10.2. CASE表达式的结果计算出来之后会被传递给窗口函数SUM OVER

2.10.3. 使用了窗口函数ROW_NUMBER,从而避免使用DISTINCT

2.11. PostgreSQL

2.12. MySQL

2.13. CASE表达式和聚合函数COUNT

2.13.1. sql

select s.sno, s.sname, s.age
  from student s, take t
 where s.sno = t.sno
 group by s.sno, s.sname, s.age
having count(*) = 2
   and max(case when cno = 'CS112' then 1 else 0 end) +
       max(case when cno = 'CS114' then 1 else 0 end) = 2

2.13.2. STUDENT表和TAKE表的内连接能够确保没有选修任何课程的学生被排除掉

2.13.3. HAVING子句的COUNT表达式只保留选修两门课程的学生

2.13.4. 只有选修了CS112和CS114两门课程的学生,其SUM结果才可能等于2

3. 问题11

3.1. 找出比其他两位学生年龄大的学生

3.1.1. 找出按照年龄从小到大排序排在第三位的学生

3.2. sql

select s5.*
  from student s5,
       student s6,
       student s7
 where s5.age > s6.age
   and s6.age > s7.age
   and s5.sno not in (
select s1.sno
  from student s1,
       student s2,
       student s3,
       student s4
 where s1.age > s2.age
   and s2.age > s3.age
   and s3.age > s4.age
)
SNO SNAME      AGE
--- ---------- ---
  1 AARON       20
  3 DOUG        20
  9 GILLIAN     20
  8 KAY         20

3.3. 找出比3名以上学生年龄大的学生

3.4. 找出比两位以上学生年龄大的学生,但又不属于第一步返回结果集的学生

3.5. DB2

3.6. Oracle

3.7. SQL Server

3.8. 窗口函数DENSE_RANK

3.8.1. sql

select sno,sname,age
  from (
select sno,sname,age,
       dense_rank()over(order by age) as dr
  from student
       ) x
 where dr = 3

3.8.2. 不仅允许Tie的存在,也能保证名次连续,中间不留空白

3.9. PostgreSQL

3.10. MySQL

3.11. 聚合函数COUNT和关联子查询

3.11.1. sql

select s1.*
 from student s1
where 2 = ( select count(*)
              from student s2
             where s2.age <s1.age )

到了这里,关于选读SQL经典实例笔记18_Exactly的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 选读SQL经典实例笔记08_区间查询

    1.6.3.1. 即使同一天入职的员工不止一个人,也只会返回一个值 1.6.4.1. 使用MIN函数来确保只返回一个值 2.2.2.1. PROJ_START和PROJ_END的值决定哪些行属于同一个区间 2.2.2.2. 如果某一行的PROJ_START值等于上一行的PROJ_END值,那么该行就是“连续”的,或者说它属于某个组 3.4.1.1. ora

    2024年02月16日
    浏览(87)
  • 选读SQL经典实例笔记14_层次查询

    2.6.1.1. sql 2.7.1.1. sql 3.5.1.1.  sql 4.5.1.1.  sql 5.5.1.1.  sql 6.7.1.1. Oracle Database 10g新增的CONNECT_BY_ROOT和CONNECT_BY_ISLEAF

    2024年02月15日
    浏览(95)
  • 选读SQL经典实例笔记05_日期运算(下)

    3.6.2.1. 对于MySQL 版本的DATEDIFF函数,需要省略第一个参数day,并把剩下的两个参数的顺序颠倒过来 4.3.2.1. Oracle早期版本

    2024年02月13日
    浏览(71)
  • 选读SQL经典实例笔记11_结果集变换

    3.6.1.1. 为了剔除掉Null,需要调用聚合函数MAX,并基于RN执行GROUP BY 3.9.1.1. 使用标量子查询基于EMPNO为每个员工排序 3.9.1.2. 针对标量子查询的返回值执行GROUP BY 3.9.1.3. 使用CASE表达式和聚合函数MAX实现结果集变换

    2024年02月16日
    浏览(72)
  • 选读SQL经典实例笔记04_日期运算(上)

    2.1.1.1. 因为X和Y之间没有任何连接条件,这里会产生笛卡儿积 2.1.1.2. X和Y都只有一条数据,因而即使没有连接条件也不会有问题,结果集最终只会有一行 2.8.1.1. 对于MySQL 而言,只需去掉DATEDIFF函数的第一个参数,并翻转ALLEN_HD和WARD_HD的顺序即可 3.1.2.1. sql 3.1.2.2. sql 3.1.2.2.

    2024年02月13日
    浏览(67)
  • 选读SQL经典实例笔记02_多表查询

    3.1.2.1. 排除重复项

    2024年02月12日
    浏览(131)
  • 选读SQL经典实例笔记01_检索和排序

    SMITH    800                           0 ALLEN   1600          300          1 WARD    1250         500          1 JONES   2975                          0 MARTIN  1250       1400         1 BLAKE   2850                         

    2024年02月11日
    浏览(109)
  • 选读SQL经典实例笔记22_2版增补

    4.1.3.1. 查找拼写不同但发音相同的字符串 6.1.1.1. 记录值的仪表存在误差 6.1.3.1. 意味着数据点是正确的,但应谨慎根据数据得出任何结论 9.1.2.1. 不使用CASE表达式或额外的连接操作

    2024年02月13日
    浏览(211)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包