51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 4107|回复: 4
打印 上一主题 下一主题

[求助] oracle 有个SQL不会写,看题目。

[复制链接]
  • TA的每日心情
    开心
    2015-8-5 00:41
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    跳转到指定楼层
    1#
    发表于 2015-8-2 13:52:35 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    问:查询和“s001”号的同学学习的课程完全相同的其他同学学号和姓名;

    脚本如下:

    create table student(
    sno varchar2(10) primary key,
    sname varchar2(20),
    sage number(2),
    ssex varchar2(5)
    );
    create table sc(
    sno varchar2(10),
    cno varchar2(10),
    score number(4,2),
    constraint pk_sc primary key (sno,cno)
    );
    insert into student values ('s001','张三',23,'男');
    insert into student values ('s002','李四',23,'男');
    insert into student values ('s003','吴鹏',25,'男');
    insert into student values ('s004','琴沁',20,'女');
    insert into student values ('s005','王丽',20,'女');
    insert into student values ('s006','李波',21,'男');
    insert into student values ('s007','刘玉',21,'男');
    insert into student values ('s008','萧蓉',21,'女');
    insert into student values ('s009','陈萧晓',23,'女');
    insert into student values ('s010','陈美',22,'女');
    commit;
    insert into sc values ('s001','c001',78.9);
    insert into sc values ('s002','c001',80.9);
    insert into sc values ('s003','c001',81.9);
    insert into sc values ('s004','c001',60.9);
    insert into sc values ('s001','c002',82.9);
    insert into sc values ('s002','c002',72.9);
    insert into sc values ('s003','c002',81.9);
    insert into sc values ('s001','c003','59');
    commit;






    求大神指点,如何写这个SQL,要求通用,如果有高级一点的写法也可以附上,谢谢。
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

  • TA的每日心情
    开心
    2020-11-16 16:29
  • 签到天数: 68 天

    连续签到: 1 天

    [LV.6]测试旅长

    2#
    发表于 2015-8-3 10:07:56 | 只看该作者
    select* from sc  where sno<>'s001'minus
    (
    select* from sc
    minus
    select * from sc where sno='s001'
    )

    评分

    参与人数 1测试积点 +10 收起 理由
    lsekfe + 10 恭喜你获得测试积点10

    查看全部评分

    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    17 分钟前
  • 签到天数: 2804 天

    连续签到: 3 天

    [LV.Master]测试大本营

    3#
    发表于 2015-8-3 13:30:19 | 只看该作者
    Select sno,sname  from student where student.sno in
    (Select distinct sno from sc where sc.cno in
    (Select cno from sc where sno = ‘s001’))
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2015-8-5 00:41
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    4#
     楼主| 发表于 2015-8-5 00:35:40 | 只看该作者
    fangty 发表于 2015-8-3 10:07
    select* from sc  where sno's001'minus
    (
    select* from sc

    看不懂,请解释一下每段的意思,逻辑。另外minus具体是怎么用法?
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    5#
    发表于 2015-8-6 09:57:34 | 只看该作者
    题目中要求“完全相同”
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-6 08:07 , Processed in 0.074496 second(s), 23 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表