文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Oracle 内、外连接

2024-04-02 19:55

关注

一、Oracle连接类型

    ☆说明:按照自己的理解划分的类型,并不是官方定义。

    1、内连接

            ①等值连接

            ②非等值连接

            ③自然连接      

    2、外连接

            ①左外连接

            ②右外连接

            ③全外连接     

二、表数据准备

                            

t表
字段a字段b
118
228
338
4NULL

t1表
字段x字段y
19
28
37

三、内连接

    1、内连接是通过inner join进行多表关联,展示查询结果,示例如下:

        SQL>select * from t inner join t1 on t.a=t1.x;

       效果展示:

Oracle 内、外连接

        说明:通过t表inner join t1表,我们得到了上图的展示效果。

    2、同样实现上图中的查询结果,我们还可以利用等值连接的方式实现

        SQL>select * from t,t1 where t.a=t1.x;

    3、inner join可以简化为join,但是实际使用中不建议这样书写,因为可读性不高。

    4、通俗的理解是等值连接、非等值连接、自然连接都是内连接这个大范畴的具体表现形式。

    5、不等值连接可以用where和inner join两种方式实现

        SQL>select * from t inner join t1 on t.a<>t1.x;

        SQL>select * from t,t1 where t.a<>t1.x;
        上面这两句sql的展示结果是相同的。

    6、自连接(self join)是SQL语句中经常要用的连接方式,使用自连接可以将自身表的一个镜像当作另一个表来对待,从而能够得到一些特殊的数据。

        例如:select * from employee worker,employee manger where worker.id=manger.id

四、外连接

    1、左外连接:通过关键字left join实现,全写是left out join,实际操作过程中一般写作left join,还可以通过在右侧连接值后加(+)来代替,左连接的意思是两表关联,显示查询数目以左表为准,但是约束受到右表的影响,对于不符合等值的情况,用NULL代替,如下例:

Oracle 内、外连接说明:首先通过等值连接,正常把前3行数据关联显示出来,之所以显示第4行是因为sql语句是左连接,正如我们所述,数据展示条数以左表为准,但是不符合要求的统统用NULL进行了填充。

    2、右连接:与左连接相反,核心思想相同,只要熟练掌握左连接,右连接自然无师自通。

    3、关于(+)使用的注意事项:

(+)操作符只能出现在where子句中,并且不能与outer join语法同时使用。

当使用(+)操作符执行外连接时,如果在where子句中包含有多个条件,则必须在所有条件中都包含(+)操作符

(+)操作符只适用于列,而不能用在表达式上。

(+)操作符不能与or和in操作符一起使用。

(+)操作符只能用于实现左外连接和右外连接,而不能用于实现完全外连接。 

4、全外连接:通过full join关键字连接实现,左边和右表都不受限制,两表都不满足条件的情况都用NULL填充,全外连接不支持(+)这种写法,即不能在左表和右表两边都写(+)。

        SQL> select * from t full join t1 on t.a=t1.x;

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯