帕卡皮卡 2022-03-23 20:39 采纳率: 100%
浏览 652
已结题

SQL查询同时选修了操作系统和数据库两门课的学生

单独查询数据库

img


单独查询操作系统

img


两个都查询,明明有一个学生两门课都选了,为什么查询不出来

img

  • 写回答

1条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2022-03-23 21:37
    关注

    img

    你这个写法不是画蛇添足么? cname本来就是课程名称,你这段sql就等同于 cname='操作系统' ,同理,下面那段 等同于 cname='数据库' ,第三个sql就变成了

     cname='操作系统' and cname='数据库'
    

    等价于

    '操作系统'='数据库'
    

    这个条件怎么可能查出数据嘛

    要找出同时参与了指定两个课程的人,初学者的思路一般是先分别取得两个课程对应的姓名清单,然后再同时去in这两个姓名清单,但你这又变成了in课程,当然不对。
    另外,更加合理的做法应该是,在where 条件 里in这两门课程,然后按姓名group by ,取having count(课程)=2的,这样就不需要重复查询这些表了

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 9月24日
  • 已采纳回答 9月16日
  • 创建了问题 3月23日

悬赏问题

  • ¥15 精通抖音评论点赞接口的来!需要开发
  • ¥15 VB.NET2022如何生成发布成exe文件
  • ¥30 matlab appdesigner私有函数嵌套整合
  • ¥15 给我一个openharmony跑通webrtc实现视频会议的简单demo项目,sdk为12
  • ¥15 vb6.0使用jmail接收smtp邮件并另存附件到D盘
  • ¥30 vb net 使用 sendMessage 如何输入鼠标坐标
  • ¥15 关于freesurfer使用freeview可视化的问题
  • ¥100 谁能在荣耀自带系统MagicOS版本下,隐藏手机桌面图标?
  • ¥15 求SC-LIWC词典!
  • ¥20 有关esp8266连接阿里云