`

连接 理解

    博客分类:
  • sql
 
阅读更多

 left join 就是关联,右表多出来不相干 关联不上不要,右边少了以空代替,保证左表全出来,如果右边重复记录,则左表关联上部分也重复。总结就是,左表只会多(重复、因右表重复)不会少,右表关联不上则为空。   

 

1       1

         1

2       2

a.id=b.id  

左边和右边两个都等,左边就会重复一条记录出来

~~~~~~~~~

内连接取交集

左外连接 取左表全部 ,若没有关联上右表为空,内在正常关联。(先关联,若没关联上,则右表用空记录,左表全出来)

1     3

2     4

3     5

得到

1   空

2   空

3    3

---------------------------------------------不错的总结----------------来源 https://bbs.csdn.net/wap/topics/390641681

left join查询:左边全部显示;右边符合条件就显示,不符合条件则为null.
right join查询:右边全部显示;左边符合条件就显示,不符合条件则为null.
inner join查询:只有两边都符合条件的才列出来。

full join =(left join) + (right join) + (inner join) 的集合

无论是左联还是右联,where 的过滤条件都select查询中生效

无论是左联还是右联,where 的过滤条件都select查询中生效

~~~~~~~~~~~~~~~~~~

没啥“好处”,但是有“用处”,这三种都叫外联结,是为了获取某些情况下需要显示,但是没有可关联的数据,如果不用外联,则只能显示出有关联的数据,还有另外一种cross join,这个不需要关联,叫做笛卡儿积,左表的行数乘以右表的行数

 

~~~~~~~~~~~~~~

而(+)这种语法也不能说是oracle的特有的,像sql server就有*=的用法

~~~~~

left join 是显示左表的所有记录,inner join 是显示所有可以关联到的记录,如果两张表数据一一对应(即:a表有一条,b表也有一条与之在join key上对应),那么结果是一样的

 

---------------------- https://bbs.csdn.net/topics/90279768

通常是 Left join 比 Inner Join 要快些

 (左表多 left join 耗时

左表少 left join 省时 ) ---不一定对

 

left join 是以A表有的数据对应B表的数据。根A、B表的数据量决定速度的快慢,和A、B的列的索引也是速度的一个要素。(定义条件的列)

inner join 是内部连接 等同 A,B表的 同时作为条件互相约束,left join 是的A表作为约束。所以理论上 left join 是要比inner join 快

~~~~~~~~~

 

我认为左连接的只判断右表中的数据是否符合要求,所以速度就会快一些,而inner join 则要判断两个表的!
分享到:
评论

相关推荐

    Java实现Socket长连接和短连接

    在Java编程中,Socket是网络通信的基础,它允许两个应用程序通过TCP/IP协议进行数据传输。Socket连接分为两种类型:长连接和短连接...通过深入理解这些概念和技术,可以有效地优化网络服务,提升应用的性能和用户体验。

    JAVA 连接池 超好理解

    连接池 JAVA 数据库 很好理解 你只需要 读一下你的 配置文件 就可以了

    超详细超易理解的JDBC连接数据库

    本文是小编的学习经验,介绍了小编自己的理解和看法,我想对你学习jdbc的帮助应该会很大。一文在手,以后不愁

    kafka生产者连接池

    在分布式消息系统中,Kafka是一个广泛使用的高吞吐量、低延迟的开源消息队列。为了优化性能和提高...在实际开发中,理解和运用好连接池,能够显著提升系统的吞吐量和响应速度,降低资源消耗,从而提高整体服务质量。

    TCP长短连接简单Demo

    本Demo是用C++语言在VS2017环境下编写的,旨在帮助开发者理解TCP长连接和短连接的实现。 首先,我们要理解TCP连接的基本概念。TCP是一种面向连接的、可靠的、基于字节流的传输层通信协议。它在两个通信实体间建立...

    socket短连接和长连接 多线程的应用

    学习这个框架可以帮助理解如何在实际应用中有效地管理和使用Socket连接,以及如何通过多线程和线程池优化并发性能。通过阅读和分析源码,可以深入理解这些概念,并提升网络编程和并发处理的能力。

    连接数测试工具 用户测试ISP给你多少连接数

    总的来说,这个工具可以帮助用户量化和理解ISP提供的网络服务质量,尤其是在处理大量并发连接时的性能。这对于需要稳定高速网络环境的用户,比如在线游戏玩家、视频流媒体爱好者或者需要进行大量文件传输的工作者来...

    连接数测试工具.rar

    它会测量在并发连接下,网络带宽的使用情况,帮助用户理解在多个连接同时运行时,是否会出现带宽瓶颈。 4. **ISP连接并发数测试**:这是对ISP网络基础设施的一个关键评估,检查在高并发情况下,如在线游戏、视频流...

    自己实现的ActiveMQ连接池和新版本ActiveMQ自带的连接池,封装好的工具类,可直接使用

    连接池是一种资源管理技术,通过复用已建立的数据库连接或网络连接,减少创建和销毁连接的开销,提高系统的性能和响应速度。 首先,我们来看自定义的ActiveMQ连接池。作者自己实现的连接池通常是为了满足特定场景下...

    oracle 数据库,在C++中用连接池实现高速连接与访问.rar

    在IT领域,数据库管理和高效的系统性能是至关重要的。Oracle数据库是一种广泛应用的关系型...理解并掌握这些知识点,对于开发人员来说至关重要,能帮助他们在面对大数据量、高并发的场景时,更好地设计和优化系统。

    C# socket异步长连接

    "长连接"是指一旦客户端和服务端建立连接,就会保持该连接状态,直到其中一方主动断开连接。在长连接模式下,客户端可以反复发送和接收数据,而无需每次都重新建立连接,减少了网络资源的消耗和连接建立的时间成本。...

    Java 连接池实现

    在Java中,我们可以通过手动实现连接池来理解其工作原理,这通常涉及到以下几个核心概念和技术: 1. **数据库连接**:在Java中,我们通常使用JDBC(Java Database Connectivity)API来与数据库交互。一个数据库连接...

    Mina长连接短连接实例

    同时,提供的文档将有助于我们更深入地理解Mina的工作原理和最佳实践。 总结来说,Apache Mina为开发者提供了一种强大的工具,用以构建高效、可扩展的网络应用。通过掌握长连接和短连接的概念,以及Mina框架的使用...

    C#连接ModbusTCP连接示例

    总的来说,"C#连接ModbusTCP连接示例"涵盖了网络通信、设备控制和用户界面设计等多个方面,对于理解和实践工业自动化系统的开发具有重要意义。无论是WinForm还是WPF,掌握这些技能都将使你在面对类似项目时更加...

    Java 连接池源码

    总的来说,理解和实现Java连接池源码是一项有价值的实践,它能帮助开发者更好地控制数据库连接,提升应用性能,同时也为理解和优化现有的连接池库提供基础。通过分析个人实现的源码,你可以深入学习连接池的工作原理...

    java socket连接池

    首先,理解Socket的基础知识至关重要。Socket是网络编程的基本接口,它提供了进程间通信(IPC)的能力,尤其是在互联网上不同主机间的通信。Java中的Socket类和ServerSocket类分别代表客户端和服务器端的通信端点,...

    RenCi.SSHNet 编程连接思科Cisco华为HUAWEI华三H3C交换机的VB.net代码,C+.net有基础的很容易理解。

    RenCi.SSHNet 编程连接思科Cisco华为HUAWEI华三H3C交换机的VB.net代码,C+.net有基础的很容易理解。 在网络上各位大大编写的基础上,整理并重新编写了基于RENCI.sshnet模块使用ssh加密连接交换机并进行会话对话的...

    C# Socket连接池

    首先,理解Socket连接池的概念。Socket是网络通信的基础,每个Socket实例代表一个网络连接。当频繁创建和销毁Socket时,会消耗大量系统资源,如内存和CPU。为了解决这个问题,引入了连接池,即预先创建一定数量的...

    程序创建ADSL连接

    在使用这个DLL时,开发者需要理解其接口,调用适当的函数来创建、查询或管理ADSL连接。 总的来说,"程序创建ADSL连接"是一个涉及网络编程、RAS API、PPP协议和DLL使用等多个技术层面的复杂任务。对于VC2005开发者,...

    java ftpClient 连接池设计

    在Java开发中,FTP(File Transfer Protocol)客户端的连接池设计是提高系统性能和资源管理效率的重要技术。连接池允许程序重复使用...通过理解连接池的工作原理和实现方式,开发者可以更好地设计和优化自己的FTP服务。

Global site tag (gtag.js) - Google Analytics