V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Jolly23
V2EX  ›  Oracle

SQL 语句问题:同时查询两个表,获取同一用户信息,当其中一表没有数据另一表有数据,怎么才能让它返回不为空?

  •  
  •   Jolly23 · 2016-07-08 14:20:23 +08:00 · 6126 次点击
    这是一个创建于 3067 天前的主题,其中的信息可能已经有所发展或是发生改变。

    select NEWJW.XS_XJB.XM, NEWJW.XS_GRXXB.DH, NEWJW.XS_GRXXB.EMAIL from NEWJW.XS_XJB, NEWJW.XS_GRXXB where NEWJW.XS_XJB.XH = 学号 and NEWJW.XS_GRXXB.XH = 学号

    两个表: NEWJW.XS_XJB NEWJW.XS_GRXXB

    返回 3 个信息,其中第一个来自表 1 ,第 2/3 个来自表 2

    现在遇到了这样一个问题: 当两个表都有这个 学号 的信息时,返回 3 个数据,正常。 当 NEWJW.XS_GRXXB 表没有信息, NEWJW.XS_XJB 表有此人信息时,执行此 sql 语句返回为空

    想要: 当 NEWJW.XS_GRXXB 表没有信息时,返回 NEWJW.XS_XJB 查询到的信息,NEWJW.XS_GRXXB没有的信息为 Null ,这个语句该怎么改呢?

    数据库是 oracle10g

    3 条回复    2016-07-08 15:31:32 +08:00
    SpicyCat
        1
    SpicyCat  
       2016-07-08 14:40:20 +08:00
    搜索 “左连接” 或者 “右连接” 或者 “外连接”
    liaowu
        2
    liaowu  
       2016-07-08 14:44:05 +08:00
    where NEWJW.XS_XJB.XH = NEWJW.XS_GRXXB.XH(+)
    and NEWJW.XS_XJB.XH = 学号
    dexterzzz
        3
    dexterzzz  
       2016-07-08 15:31:32 +08:00
    full inner join
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1174 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 00:00 · PVG 08:00 · LAX 16:00 · JFK 19:00
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.