SQL中JOIN和UNION区别、用法及示例介绍
join 是两张表做交连后里面条件相同的部分记录产生一个记录集,union是产生的两个记录集(字段要一样的)并在一起,成为一个新的记录集
1.JOIN和UNION区别join 是两张表做交连后里面条件相同的部分记录产生一个记录集,
union是产生的两个记录集(字段要一样的)并在一起,成为一个新的记录集 。
JOIN用于按照ON条件联接两个表,主要有四种:
INNER JOIN:内部联接两个表中的记录,仅当至少有一个同属于两表的行符合联接条件时,内联接才返回行。我理解的是只要记录不符合ON条件,就不会显示在结果集内。
LEFT JOIN / LEFT OUTER JOIN:外部联接两个表中的记录,并包含左表中的全部记录。如果左表的某记录在右表中没有匹配记录,则在相关联的结果集中右表的所有选择列表列均为空值。理解为即使不符合ON条件,左表中的记录也全部显示出来,且结果集中该类记录的右表字段为空值。
RIGHT JOIN / RIGHT OUTER JOIN:外部联接两个表中的记录,并包含右表中的全部记录。简单说就是和LEFT JOIN反过来。
FULL JOIN / FULL OUTER JOIN:完整外部联接返回左表和右表中的所有行。就是LEFT JOIN和RIGHT JOIN和合并,左右两表的数据都全部显示。
JOIN的基本语法:
Select table1.* FROM table1 JOIN table2 ON table1.id=table2.id
sql写法
内连接inner join:
代码如下:
SELECT msp.name, party.name
FROM msp JOIN party ON party=code
或
代码如下:
SELECT msp.name, party.name
FROM msp inner JOIN party ON party=code
左连接left join :
代码如下:
SELECT msp.name, party.name
FROM msp LEFT JOIN party ON party=code
右连接right join :
代码如下:
SELECT msp.name, party.name
FROM msp RIGHT JOIN party ON msp.party=party.code
全连接(full join):
代码如下:
SELECT msp.name, party.name
FROM msp FULL JOIN party ON msp.party=party.code
UNION运算符
将两个或更多查询的结果集组合为单个结果集,该结果集包含联合查询中的所有查询的全部行。UNION的结果集列名与UNION运算符中第一个Select语句的结果集的列名相同。另一个Select语句的结果集列名将被忽略。
其中两种不同的用法是UNION和UNION ALL,区别在于UNION从结果集中删除重复的行。如果使用UNION ALL 将包含所有行并且将不删除重复的行。
UNION和UNION ALL的区别:
union 检查重复
union all 不做检查
比如 select 'a' union select 'a' 输出就是一行 a
比如 select 'a' union all select 'a' 输出就是两行 a
2. 通过下面的例子,可以清晰的看出和理解2者的区别
实例1 典型的二表连接演示
假定有两个表Table1和Table2,其包含的列和数据分别如表1.1和表1.2所示。
表1.1 Table1数据库表
表1.2 Table2数据库表
Table1和Table2表共有的列为ColumnA,如果通过ColumnA列的值连接Table1和Table2两个表,即连接条件为Table1.ColumnA=Table2.ColumnA,此时得到的连接结果如表1.3所示。
表1.3 连接Table1和Table2表
上述连接过程的实现代码可表示如下:SELECT * FROM Table1 JOIN Table2 ON Table1.ColumnA=Table2.columnA
实例2 典型的二表记录的UNION运算
假定有两个表Table3和Table4,其包含的列和数据分别如表2.1和表2.2所示。
表2.1 Table3数据库表
表2.2 Table4数据库表、
Table3表和Table4表具有相同的列结构,列数也要相同,列名可以不同,以第一个表的列名为新表的列名,因此可以使用UNION运算符连接两个表的记录集,得到的连接结果如表2.3所示。
表2.3 使用UNION连接Table3表和Table4表的记录
上述连接过程的实现代码可表示如下:SELECT * FROM Table3 UNION SELECT *FROM Table4
对比实例1和实例2,不难发现二者的区别。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











JOIN의 의미는 두 개의 테이블을 연결하는 영어 단어 'join'과 같으며 크게 Inner Join, Outer Join, Right Join, Left Join, Natural Join으로 나눌 수 있습니다. 먼저 두 개의 테이블을 생성합니다. 다음은 예제로 사용됩니다. CREATETABLEt_blog(idINTPRIMARYKEYAUTO_INCREMENT,titleVARCHAR(50),typeIdINT);SELECT*FROMt_blog;+----+------+---------+ | id|제목|유형 ID|+---+-------+---------+|1|aaa|1||2|bbb|2||3|ccc|3 |

조인 유형 leftjoin은 왼쪽 테이블을 구동 테이블로 사용하고 왼쪽 테이블을 결과 집합의 기반으로 사용합니다. rightjoin은 오른쪽 테이블을 구동 테이블로 사용합니다. 결과 집합의 기초는 왼쪽 테이블을 연결합니다. 데이터는 결과 집합 innerjoin에 추가됩니다. 결과 집합은 두 테이블의 합집합을 취합니다. Union은 Union을 대체합니다. Union과 Unionall의 차이점은 where 조건이 사용되지 않으면 결과 집합이 두 개의 연결된 테이블 행의 곱이 된다는 것입니다. crossjoin은 결과 세트를 생성하며 on 조건에 따라 전달됩니다.

C 언어에서 Union을 사용하면 서로 다른 데이터 유형을 동일한 메모리 위치에 저장할 수 있는 특수 데이터 유형이 됩니다. Union을 사용하면 메모리 공간을 절약하고 서로 다른 데이터 유형 간의 변환을 용이하게 할 수 있습니다. Union을 사용할 경우 해당 멤버가 유효하며 동시에 하나의 멤버에만 접근할 수 있다는 점에 유의해야 합니다.

소개 A의 고유 + AB의 공개 B의 고유 + AB의 공개 AB의 공개 A의 고유 B의 고유 A의 고유 + B의 고유 + AB의 공개 A의 고유 + B의 고유 테이블 부서 테이블 만들기 연습 DROPTABLEIFEXISTS`dept`;CREATETABLE`dept`(`dept_id`int( 11)NOTNULLAUTO_INCREMENT,`dept_name`varchar(30)DEFAULTNULL,`dept_number`int(11)DEFAULTNULL,PRIMARYKEY(`dept_id`))ENGINE =InnoDBAUT

조인 쿼리 및 다중 쿼리와 비교할 때 MySQL 다중 테이블 관련 쿼리 또는 다중 단일 테이블 쿼리 중 어느 것이 더 효율적입니까? 데이터의 양이 충분히 크지 않으면 조인을 사용하는 데 문제가 없지만 일반적으로 서비스 계층에서 수행됩니다. 첫째: 단일 시스템 데이터베이스의 컴퓨팅 리소스는 매우 비싸고 데이터베이스는 두 가지 쓰기를 모두 제공해야 합니다. 동시에 읽기에는 CPU 소비가 필요합니다. 데이터베이스를 만들기 위해 처리량이 높아지고 비즈니스는 수백 마이크로초에서 밀리초의 지연 간격에 신경 쓰지 않게 됩니다. 결국 컴퓨팅 리소스는 수평적으로 쉽게 확장할 수 있고 데이터베이스는 어렵기 때문에 대부분의 비즈니스는 순수한 컴퓨팅 작업을 서비스 계층에 두고 데이터베이스를 트랜잭션 기능을 갖춘 kv 시스템으로 사용하게 됩니다.

MySQL에서 FULLOUTERJOIN 함수를 사용하여 두 테이블의 통합을 얻는 방법 MySQL에서 FULLOUTERJOIN 함수는 내부 조인과 외부 조인을 결합하는 강력한 조인 작업입니다. 두 테이블의 통합, 즉 두 테이블의 모든 데이터를 단일 결과 집합으로 결합하는 데 사용할 수 있습니다. 이 기사에서는 FULLOUTERJOIN 함수의 사용법을 소개하고 독자의 이해를 돕기 위해 몇 가지 샘플 코드를 제공합니다. FULLOUTERJOIN 함수

1. Union은 다중 테이블 연결 쿼리 방식이 아닌, 여러 질의문의 질의 결과를 하나의 결과로 결합하여 중복되는 데이터를 제거하는 방식입니다. 2. 완전 외부 조인은 왼쪽 테이블과 오른쪽 테이블의 데이터를 쿼리한 후 연결 조건에 따라 연결합니다. 예시 #왼쪽 외부 Aunion 및 오른쪽 외부 Aunion 사용 BSELECT*FROMt_categorycLEFTOUTERJOINt_productpONc.cid=p.cnounionSELECT*FROMt_categorycRIGHTOUTERJOINt_productpONc.cid=p.cno

데이터 본문의 공존을 구현하기 위해 Union 클래스를 정의합니다. C/C++ 언어에서 Union이라고도 하는 Union은 구조체와 유사한 데이터 구조입니다. 구조체와 마찬가지로 공용체에는 많은 데이터 유형과 변수가 포함될 수 있습니다. 둘 사이의 차이점은 다음과 같습니다. 구조체의 모든 변수는 "공존"하며, 각 변수는 서로 다른 메모리 공간을 차지합니다. 공용체에서 각 변수는 "상호 배타적"이며 동시에 하나의 변수만 유효하며 모든 변수는 동일한 메모리 공간을 차지합니다. 여러 데이터가 메모리를 공유해야 하거나 한 번에 여러 데이터 중 하나만 가져와야 하는 경우 공용체를 사용할 수 있습니다. 자바에서
