Max_inner 2017-10-27 03:08 采纳率: 0%
浏览 943
已结题

Oracle 自然连接后投影重复

** oracle 10.2.1,PL/SQL**

具体要求: _ 查询学分修满25分的同学姓名和学分详情_

表结构,忽略约束条件

--学生信息表:student_info
create table student_info
(
    stuid      int,                 --学号
    stuname    varchar2(20),            --姓名
    stusex     char(4),                 --性别
    birthday   date default (sysdate),  --出生年月 
    cellphone  int,                 --手机号
    address    varchar2(40),            --家庭地址
        Email      varchar2(20),            --邮箱
        classno    int                  --所属班级
);
commit;

--课程信息表:course_info
create table course_info
(
    cno         varchar2(10),         --课程编号
    cname       varchar2(20),         --课程名称
    cstart      int,                --课程开始学期
    cperiod     int,                  --课时
    ccredits    number(2,1)           --学分
);
commit;

--成绩信息表: score_info
create table score_info
(
    stuid       int,         --学号
    cno         varchar2(10),        --课程编号
    score       int          --成绩
);
commit;
  1. select *
select *
        from (student_info natural join score_info) natural join course_info
        where stuid in (select stuid
                        from score_info natural join course_info
                        group by stuid
                            having sum(ccredits)>=25
                        );

输出,此时并无重复

  1. select stuname,ccredits
select stuname,ccredits
    from (student_info natural join score_info) natural join course_info
        where stuid in (select stuid
                        from score_info natural join course_info
                        group by stuid
                            having sum(ccredits)>=25
                            );

输出,此时出现重复

  1. 当改为下面语句时正常
select stuname,ccredits 
    from ((select *
    from (student_info natural join score_info) natural join course_info
    where stuid in (select stuid
            from score_info natural join course_info
            group by stuid
              having sum(ccredits)>=25
            )

输出,无异常

提问:如何解决 2例 中的重复问题?

  • 写回答

1条回答 默认 最新

  • threenewbee 2017-10-27 03:23
    关注

    用group by去重,自然连接用的是笛卡尔集

    评论

报告相同问题?

悬赏问题

  • ¥15 求差集那个函数有问题,有无佬可以解决
  • ¥15 【提问】基于Invest的水源涵养
  • ¥20 微信网友居然可以通过vx号找到我绑的手机号
  • ¥15 寻一个支付宝扫码远程授权登录的软件助手app
  • ¥15 解riccati方程组
  • ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
  • ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
  • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
  • ¥50 树莓派安卓APK系统签名
  • ¥65 汇编语言除法溢出问题