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

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 Opencv配置出错
  • ¥15 模电中二极管,三极管和电容的应用
  • ¥15 关于模型导入UNITY的.FBX: Check external application preferences.警告。
  • ¥15 气象网格数据与卫星轨道数据如何匹配
  • ¥100 java ee ssm项目 悬赏,感兴趣直接联系我
  • ¥15 微软账户问题不小心注销了好像
  • ¥15 x264库中预测模式字IPM、运动向量差MVD、量化后的DCT系数的位置
  • ¥15 curl 命令调用正常,程序调用报 java.net.ConnectException: connection refused
  • ¥20 关于web前端如何播放二次加密m3u8视频的问题
  • ¥15 使用百度地图api 位置函数报错?