목차
内连接与左右连接
内连接的匹配方式
左右连接的匹配过程
데이터 베이스 MySQL 튜토리얼 mysql左连接,右连接,内连接学习体会

mysql左连接,右连接,内连接学习体会

Jun 07, 2016 pm 03:33 PM
mysql 성명 연결하다

声明:本文为本人在分析学习了其他网友的博文后,得出的一些体会。。编写本文的目的,一则,分享自己的学习体会,希望通过此文与其他正在学习数据库的网友互相交流,共同学习;二则,记录下学习中的点滴收获,供以后温习。本人为数据库初学者,有很多观点可

声明:本文为本人在分析学习了其他网友的博文后,得出的一些体会。。编写本文的目的,一则,分享自己的学习体会,希望通过此文与其他正在学习数据库的网友互相交流,共同学习;二则,记录下学习中的点滴收获,供以后温习。本人为数据库初学者,有很多观点可能存在错误,若诸位网友有不同观点,望不吝指教。

首先引用一下这位网友的博文,本人从此博文中受益良多,感谢此位网友的分享。

http://hi.baidu.com/woaidelphi/item/d96be15c3ce2c1cbd2e10c6c

author:华夏之星
QQ:1019822077
email:woai_php@sina.com

内连接: 只连接匹配的行
左外连接: 包含左边表的全部行(不管右边的表中是否存在与它们匹配的行),以及右边表中全部匹配的行
右外连接: 包含右边表的全部行(不管左边的表中是否存在与它们匹配的行),以及左边表中全部匹配的行
注:此博文中还讲述了其他连接方式,鉴于本人刚开始学习数据库,因此,仅研究较为普遍的3中方式。

内连接与左右连接

在网上看到很多讲述内连接和左右连接的博文,一直认为这是3类连接方式。但看完这篇博文后,认识到,其实这3中连接方式,实际可以分为

两类。一种内连接,一种外连接。而外连接又可分为左连接和右连接。

内连接的匹配方式

------------------------------------------------------------------------------再次引用-----------------------------------------------------------------------

举个例子吧。
表A
id   name  
1    张
2    李
3    王

表B
id   address   A_id
1    北京      1
2    上海      3
3    南京      10

/******************************** inner join  内连接*****************************************/
排他性:A,B表中至少有1个匹配时,才返回行。两表的交集
SQL语句如下:
select A.name,B.address from A 
inner join B
on A.id = B.A_id

查询结果为:
name     address
张     北京
王     上海

------------------------------------------------------------------------------引用结束-----------------------------------------------------------------------

        此sql查询语句可按如下翻译:使用内连接的方式,选择出A中id与B中A_id相等的A表和B表中的行,然后将A表中行的name字段和B表中的address字段组合成行,作为查询结果。

        具体过程可以描述为,对于A表中id为1的行(及表中第一行),与B表中的每一行都进行匹配,找到与B表中A_id字段相同的行(本例中B表的第一行便满足条件)。由于本例中,A表的第一行和B表的第一行便满足SQL语句的查询条件,因此,查询结果集的第一条结果为A表第一行的name(张)和B表第一行的address(北京)。然后,对A表的第二行进行匹配,遍历B表的所有行,没有找到满足与A表id(2)相同的A_id的行,因此。接着为A表的第3行,在B表中寻找匹配的行。遍历B表中所有的行,发现第二行的A_id(3)与A表id(3)匹配,因此,匹配成功,输出结果。自此,A表的所有行的查询了,本次SQL查询结束。结果有两条匹配的结果。

左右连接的匹配过程

--------------------------------------------------------------------------接着引用---------------------------------------------------------------

表A
id   name  
1    张
2    李
3    王

表B
id   address   A_id
1    北京      1
2    上海      3
3    南京      10

/******************************** left join  左连接*****************************************/
包容性:A表包容B表,左连接左表是全的.(left join 或 left outer join )
SQL语句如下:
SELECT A.name, B.address
FROM A
LEFT JOIN B ON A.id = B.A_id 
查询结果为:
name     address
张     北京
李     NULL
王     上海
/******************************** right join  右连接*****************************************/
包容性:B表包容A表,右连接右表是全的.(right join 或 right outer join )
SQL语句如下:
SELECT A.name, B.address
FROM A
RIGHT JOIN B ON A.id = B.A_id 
查询结果为:
name     address
张     北京
王     上海
NULL     南京        

------------------------------------------------------------------------------引用结束-----------------------------------------------------------------------

        左右连接的匹配过程与内连接的匹配过程相同,不同的是,左右连接查询时,SQL语句中,指定的基准表(right join 或left join 后的表)字段

无论是否在另一张表中有与之匹配的行,基准表中的字段均会输出。如上例左连接中的第二行,李(左连接基准表指定的查询字段)和右连接中的

第3行南京(右连接基准表中指定的查询字段)

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP의 빅데이터 구조 처리 능력 PHP의 빅데이터 구조 처리 능력 May 08, 2024 am 10:24 AM

PHP의 빅데이터 구조 처리 능력

PHP에서 MySQL 쿼리 성능을 최적화하는 방법은 무엇입니까? PHP에서 MySQL 쿼리 성능을 최적화하는 방법은 무엇입니까? Jun 03, 2024 pm 08:11 PM

PHP에서 MySQL 쿼리 성능을 최적화하는 방법은 무엇입니까?

PHP에서 MySQL 백업 및 복원을 사용하는 방법은 무엇입니까? PHP에서 MySQL 백업 및 복원을 사용하는 방법은 무엇입니까? Jun 03, 2024 pm 12:19 PM

PHP에서 MySQL 백업 및 복원을 사용하는 방법은 무엇입니까?

PHP를 사용하여 MySQL 테이블에 데이터를 삽입하는 방법은 무엇입니까? PHP를 사용하여 MySQL 테이블에 데이터를 삽입하는 방법은 무엇입니까? Jun 02, 2024 pm 02:26 PM

PHP를 사용하여 MySQL 테이블에 데이터를 삽입하는 방법은 무엇입니까?

데이터베이스에서 Java 열거 유형의 애플리케이션 시나리오는 무엇입니까? 데이터베이스에서 Java 열거 유형의 애플리케이션 시나리오는 무엇입니까? May 05, 2024 am 09:06 AM

데이터베이스에서 Java 열거 유형의 애플리케이션 시나리오는 무엇입니까?

MySQL 8.4에서 mysql_native_password가 로드되지 않음 오류를 수정하는 방법 MySQL 8.4에서 mysql_native_password가 로드되지 않음 오류를 수정하는 방법 Dec 09, 2024 am 11:42 AM

MySQL 8.4에서 mysql_native_password가 로드되지 않음 오류를 수정하는 방법

PHP에서 MySQL 저장 프로시저를 사용하는 방법은 무엇입니까? PHP에서 MySQL 저장 프로시저를 사용하는 방법은 무엇입니까? Jun 02, 2024 pm 02:13 PM

PHP에서 MySQL 저장 프로시저를 사용하는 방법은 무엇입니까?

PHP 배열 페이징을 위한 성능 최적화 전략 PHP 배열 페이징을 위한 성능 최적화 전략 May 02, 2024 am 09:27 AM

PHP 배열 페이징을 위한 성능 최적화 전략

See all articles