찾다
데이터 베이스MySQL 튜토리얼SQL에서 조인을 사용하는 방법

sql 문의 조인 키워드는 흔히 사용되는 키워드이지만 이해하기 쉽지 않습니다. 다음 예에서는 table1, table2 테이블 생성을 간단히 설명합니다.
create table table1(id int,name varchar (10))
테이블 생성 table2(id int,score int)
insert into table1 선택 1,'lee'
insert into table1 선택 2,'zhang'
insert into table1 선택 4, 'wang'
insert into table2 select 1,90
insert into table2 select 2,100
insert into table2 select 3,70
표에 표시된 대로
--- ----- -------------------
테이블1 | 테이블2 |
----------------------------------------------- ----- -----
아이디 이름 |아이디 점수 |
1 리 |1 90 |
2 장 |2 100 |
4 왕 |3 70 |
- ----- ------------------- --

다음은 모두 쿼리 분석기에서 실행됩니다

1. 외부 조인
1. 개념: 왼쪽 외부 조인, 오른쪽 외부 조인 또는 완전 외부 조인 포함

2. 왼쪽 조인: 왼쪽 외부 조인
(1) 왼쪽 외부 조인의 결과 집합에는 조인 열과 일치하는 행뿐만 아니라 LEFT OUTER 절에 지정된 왼쪽 테이블의 모든 행이 포함됩니다. 왼쪽 테이블의 행에 오른쪽 테이블의 일치하는 행이 없으면 오른쪽 테이블의 모든 선택 목록 열은 연결된 결과 집합 행에서 null이 됩니다.
(2)sql 문
select * from table1 왼쪽 조인 table2 on table1.id=table2.id
-------------결과--------- ------
ID 이름 ID 점수
----------------------
1 리 1 90
2 장 2 100
4 왕 NULL NULL
---------------------------- ------
참고: table1의 모든 절을 포함하고, 지정된 조건에 따라 table2의 해당 필드를 반환하며, 충족되지 않으면 null을 표시합니다

3. 오른쪽 조인: 오른쪽 조인 또는 오른쪽 외부 조인
(1) 오른쪽 외부 조인은 왼쪽 외부 조인의 역조인입니다. 오른쪽 테이블의 모든 행이 반환됩니다. 오른쪽 테이블의 행과 왼쪽 테이블의 일치하는 행이 없으면 왼쪽 테이블에 대해 null이 반환됩니다.
(2)sql 문
table1에서 *를 선택하고 table1.id=table2.id에서 table2를 조인합니다
------------결과--------- ------
ID 이름 ID 점수
----------------------
1 리 1 90
2 장 2 100
NULL NULL 3 70
---------------------------- ------
참고: table2의 모든 절을 포함하고 지정된 조건에 따라 table1의 해당 필드를 반환하며 충족되지 않으면 null을 표시합니다

4. 완전 외부 조인 또는 완전 외부 조인
(1 ) 완전 외부 조인은 왼쪽 및 오른쪽 테이블의 모든 행을 반환합니다. 행에 다른 테이블에 일치하는 행이 없으면 다른 테이블의 선택 목록 열에 Null 값이 포함됩니다. 테이블 간에 일치하는 행이 있는 경우 전체 결과 집합 행에는 기본 테이블의 데이터 값이 포함됩니다.
(2)sql 문
select * from table1 완전 조인 table2 on table1.id=table2.id
------------결과--------- ------
ID 이름 ID 점수
----------------------
1 리 1 90
2 장 2 100
4 왕 NULL NULL
NULL NULL 3 70
------ --- -------
참고: 왼쪽 및 오른쪽 조인의 합계를 반환합니다(위의 왼쪽 및 오른쪽 조인 참조)

2. 내부 조인
1. 비교 연산자를 사용하여 비교합니다. 조인 열 값

2. 내부 조인: 조인 또는 내부 조인

3.sql 문
select * from table1 조인 table2 on table1.id=table2 .id
-------------결과-------------
ID 이름 ID 점수
--------- -- -----
1 리 1 90
2 장 2 100
--------------- ---
참고: 조건에 맞는 table1과 table2의 열만 반환

4. 동등(다음과 실행 효과 동일)
A:table1에서 a.*,b.* 선택 a,table2 b 여기서 a.id=b.id
B:select * from table1 교차 조인 table2 where table1.id=table2.id(참고: cross Join 사후 조건은 where, not on)

3. Cross-join(완료)

1. 개념: WHERE 절이 없는 Cross Join은 테이블을 생성합니다. Cartesian product에 참여합니다. 첫 번째 테이블의 행 수에 두 번째 테이블의 행 수를 곱한 값은 데카르트 곱 결과 집합의 크기와 같습니다. (table1과 table2의 Cross Join은 3*3=9개의 레코드를 생성합니다.)

2. Cross Join: Cross Join(조건 없음...)

3.sql문
table1 교차 조인 table2에서 * 선택
-------------결과-------------
id 이름 id 점수
--- -------------
1 리 1 90
2 장 1 90
4 왕 1 90
1 리 2 100
2 장 2 100
4 왕 2 100
1 리 3 70
2 장 3 70
4 왕 3 70
------ -- --------
참고: 3*3=9 레코드, 즉 데카르트 곱

4.etc을 반환합니다. (다음 실행 효과와 동일)
A:select * from table1,table2


성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
SQL Server使用CROSS APPLY与OUTER APPLY实现连接查询SQL Server使用CROSS APPLY与OUTER APPLY实现连接查询Aug 26, 2022 pm 02:07 PM

本篇文章给大家带来了关于SQL的相关知识,其中主要介绍了SQL Server使用CROSS APPLY与OUTER APPLY实现连接查询的方法,文中通过示例代码介绍的非常详细,下面一起来看一下,希望对大家有帮助。

SQL Server解析/操作Json格式字段数据的方法实例SQL Server解析/操作Json格式字段数据的方法实例Aug 29, 2022 pm 12:00 PM

本篇文章给大家带来了关于SQL server的相关知识,其中主要介绍了SQL SERVER没有自带的解析json函数,需要自建一个函数(表值函数),下面介绍关于SQL Server解析/操作Json格式字段数据的相关资料,希望对大家有帮助。

聊聊优化sql中order By语句的方法聊聊优化sql中order By语句的方法Sep 27, 2022 pm 01:45 PM

如何优化sql中的orderBy语句?下面本篇文章给大家介绍一下优化sql中orderBy语句的方法,具有很好的参考价值,希望对大家有所帮助。

Monaco Editor如何实现SQL和Java代码提示?Monaco Editor如何实现SQL和Java代码提示?May 07, 2023 pm 10:13 PM

monacoeditor创建//创建和设置值if(!this.monacoEditor){this.monacoEditor=monaco.editor.create(this._node,{value:value||code,language:language,...options});this.monacoEditor.onDidChangeModelContent(e=>{constvalue=this.monacoEditor.getValue();//使value和其值保持一致i

一文搞懂SQL中的开窗函数一文搞懂SQL中的开窗函数Sep 02, 2022 pm 04:55 PM

本篇文章给大家带来了关于SQL server的相关知识,开窗函数也叫分析函数有两类,一类是聚合开窗函数,一类是排序开窗函数,下面这篇文章主要给大家介绍了关于SQL中开窗函数的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下。

Monaco Editor怎么实现SQL和Java代码提示Monaco Editor怎么实现SQL和Java代码提示May 11, 2023 pm 05:31 PM

monacoeditor创建//创建和设置值if(!this.monacoEditor){this.monacoEditor=monaco.editor.create(this._node,{value:value||code,language:language,...options});this.monacoEditor.onDidChangeModelContent(e=>{constvalue=this.monacoEditor.getValue();//使value和其值保持一致i

springboot配置mybatis的sql执行超时时间怎么解决springboot配置mybatis的sql执行超时时间怎么解决May 15, 2023 pm 06:10 PM

当某些sql因为不知名原因堵塞时,为了不影响后台服务运行,想要给sql增加执行时间限制,超时后就抛异常,保证后台线程不会因为sql堵塞而堵塞。一、yml全局配置单数据源可以,多数据源时会失效二、java配置类配置成功抛出超时异常。importcom.alibaba.druid.pool.DruidDataSource;importcom.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceBuilder;importorg.apache.

如何使用exp进行SQL报错注入如何使用exp进行SQL报错注入May 12, 2023 am 10:16 AM

0x01前言概述小编又在MySQL中发现了一个Double型数据溢出。当我们拿到MySQL里的函数时,小编比较感兴趣的是其中的数学函数,它们也应该包含一些数据类型来保存数值。所以小编就跑去测试看哪些函数会出现溢出错误。然后小编发现,当传递一个大于709的值时,函数exp()就会引起一个溢出错误。mysql>selectexp(709);+-----------------------+|exp(709)|+-----------------------+|8.218407461554972

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

뜨거운 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전