MySQL左连接、右连接和内连接详解
以MySql为例。在MySQL数据库中建立两张数据表,并分别插入一些数据。 示例脚本如下: drop table table1; CREATE TABLE `andrew`.`table1` ( ` name ` VARCHAR (32) NOT NULL , `city` VARCHAR (32) NOT NULL ) ENGINE=MyISAM; insert into TABLE1( name ,ci
以MySql为例。在MySQL数据库中建立两张数据表,并分别插入一些数据。
示例脚本如下:
<ol class="dp-sql"> <li class="alt"><span><span> </span><span class="keyword">drop</span><span> </span><span class="keyword">table</span><span> table1; </span></span></li> <li> <span></span><span class="keyword">CREATE</span><span> </span><span class="keyword">TABLE</span><span> `andrew`.`table1` </span> </li> <li class="alt"><span>( </span></li> <li> <span>`</span><span class="keyword">name</span><span>` </span><span class="keyword">VARCHAR</span><span>(32) </span><span class="op">NOT</span><span> </span><span class="op">NULL</span><span>, </span> </li> <li class="alt"> <span>`city` </span><span class="keyword">VARCHAR</span><span>(32) </span><span class="op">NOT</span><span> </span><span class="op">NULL</span><span> </span> </li> <li><span>) </span></li> <li class="alt"><span>ENGINE = MyISAM; </span></li> <li> <span></span><span class="keyword">insert</span><span> </span><span class="keyword">into</span><span> TABLE1(</span><span class="keyword">name</span><span>, city) </span><span class="keyword">values</span><span> (</span><span class="string">'Person A'</span><span>, </span><span class="string">'BJ'</span><span>); </span> </li> <li class="alt"> <span></span><span class="keyword">insert</span><span> </span><span class="keyword">into</span><span> TABLE1(</span><span class="keyword">name</span><span>, city) </span><span class="keyword">values</span><span> (</span><span class="string">'Person B'</span><span>, </span><span class="string">'BJ'</span><span>); </span> </li> <li> <span></span><span class="keyword">insert</span><span> </span><span class="keyword">into</span><span> TABLE1(</span><span class="keyword">name</span><span>, city) </span><span class="keyword">values</span><span> (</span><span class="string">'Person C'</span><span>, </span><span class="string">'SH'</span><span>); </span> </li> <li class="alt"> <span></span><span class="keyword">insert</span><span> </span><span class="keyword">into</span><span> TABLE1(</span><span class="keyword">name</span><span>, city) </span><span class="keyword">values</span><span> (</span><span class="string">'Person D'</span><span>, </span><span class="string">'SZ'</span><span>); </span> </li> <li> <span></span><span class="keyword">commit</span><span>; </span> </li> <li class="alt"> <span></span><span class="keyword">drop</span><span> </span><span class="keyword">table</span><span> table2; </span> </li> <li> <span></span><span class="keyword">CREATE</span><span> </span><span class="keyword">TABLE</span><span> `andrew`.`table2` </span> </li> <li class="alt"><span>( </span></li> <li> <span>`</span><span class="keyword">name</span><span>` </span><span class="keyword">VARCHAR</span><span>(32) </span><span class="op">NOT</span><span> </span><span class="op">NULL</span><span>, </span> </li> <li class="alt"> <span>`city` </span><span class="keyword">VARCHAR</span><span>(32) </span><span class="op">NOT</span><span> </span><span class="op">NULL</span><span> </span> </li> <li><span>) </span></li> <li class="alt"><span>ENGINE = MyISAM; </span></li> <li> <span></span><span class="keyword">insert</span><span> </span><span class="keyword">into</span><span> TABLE2(</span><span class="keyword">name</span><span>, city) </span><span class="keyword">values</span><span> (</span><span class="string">'Person W'</span><span>, </span><span class="string">'BJ'</span><span>); </span> </li> <li class="alt"> <span></span><span class="keyword">insert</span><span> </span><span class="keyword">into</span><span> TABLE2(</span><span class="keyword">name</span><span>, city) </span><span class="keyword">values</span><span> (</span><span class="string">'Person X'</span><span>, </span><span class="string">'SH'</span><span>); </span> </li> <li> <span></span><span class="keyword">insert</span><span> </span><span class="keyword">into</span><span> TABLE2(</span><span class="keyword">name</span><span>, city) </span><span class="keyword">values</span><span> (</span><span class="string">'Person Y'</span><span>, </span><span class="string">'SH'</span><span>); </span> </li> <li class="alt"> <span></span><span class="keyword">insert</span><span> </span><span class="keyword">into</span><span> TABLE2(</span><span class="keyword">name</span><span>, city) </span><span class="keyword">values</span><span> (</span><span class="string">'Person Z'</span><span>, </span><span class="string">'NJ'</span><span>); </span> </li> <li> <span></span><span class="keyword">commit</span><span>; </span> </li> </ol>
1. MySQL外连接 – 左连接结果
table1居左,故谓之左连接。这种情况下,以table1为主,即table1中的所有记录均会被列出。有一下三种情况:
a. 对于table1中的每一条记录对应的城市如果在table2中也恰好存在而且刚好只有一条,那么就会在
返回的结果中形成一条新的记录。如上面Person A和Person B对应的情况。
b. 对于table1中的每一条记录对应的城市如果在table2中也恰好存在而且有N条,那么就会在返回的结果中形成N条新的记录。如上面的Person C对应的情况。
c. 对于table1中的每一条记录对应的城市如果在table2中不存在,那么就会在返回的结果中形成一条
条新的记录,且该记录的右边全部NULL。如上面的Person D对应的情况。
不符合上面三条规则的记录不会被列出。
2. MySQL外连接 – 右连接结果
table2居右,故谓之右连接。这种情况下,以table2为主,即table2中的所有记录均会被列出。有一下三种情况:
a. 对于table2中的每一条记录对应的城市如果在table1中也恰好存在而且刚好只有一条,那么就会在
返回的结果中形成一条新的记录。如上面Person X和Person Y对应的情况。
b. 对于table2中的每一条记录对应的城市如果在table1中也恰好存在而且有N条,那么就会在返回的结果中形成N条新的记录。如上面的Person W对应的情况。
c. 对于table2中的每一条记录对应的城市如果在table1中不存在,那么就会在返回的结果中形成一条
条新的记录,且该记录的左边全部NULL。如上面的Person Z对应的情况。
不符合上面三条规则的记录不会被列出。
3. MySQL内连接
MySQL内连接的数据记录中,不会存在字段为NULL的情况。可以简单地认为,内链接的结果就是在左连接或者右连接的结果中剔除存在字段为NULL的记录后所得到的结果。甚至可以认为,如果两个表中仅分别剩下内连接运算后所得的数据记录,如table1中只有Person A、Person B和Person C,table2中只有Person W、Person X和Person Y,那么这两个表的之间的左连接和右连接的返回的结果是一样的。
注意:select * from table1 a inner join table2 b on a.city = b.city 和select * from table1 a join table2 b on a.city = b.city 的效果是一样的,即如果join的左边没有诸如left、right或者inner这样的关键字时,缺省的是内连接。另外,MySQL不支持full join。

핫 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)

뜨거운 주제











MySQL 데이터베이스에서 사용자와 데이터베이스 간의 관계는 권한과 테이블로 정의됩니다. 사용자는 데이터베이스에 액세스 할 수있는 사용자 이름과 비밀번호가 있습니다. 권한은 보조금 명령을 통해 부여되며 테이블은 Create Table 명령에 의해 생성됩니다. 사용자와 데이터베이스 간의 관계를 설정하려면 데이터베이스를 작성하고 사용자를 생성 한 다음 권한을 부여해야합니다.

MySQL은 설치가 간단하고 강력하며 데이터를 쉽게 관리하기 쉽기 때문에 초보자에게 적합합니다. 1. 다양한 운영 체제에 적합한 간단한 설치 및 구성. 2. 데이터베이스 및 테이블 작성, 삽입, 쿼리, 업데이트 및 삭제와 같은 기본 작업을 지원합니다. 3. 조인 작업 및 하위 쿼리와 같은 고급 기능을 제공합니다. 4. 인덱싱, 쿼리 최적화 및 테이블 파티셔닝을 통해 성능을 향상시킬 수 있습니다. 5. 데이터 보안 및 일관성을 보장하기위한 지원 백업, 복구 및 보안 조치.

Navicat 자체는 데이터베이스 비밀번호를 저장하지 않으며 암호화 된 암호 만 검색 할 수 있습니다. 솔루션 : 1. 비밀번호 관리자를 확인하십시오. 2. Navicat의 "비밀번호 기억"기능을 확인하십시오. 3. 데이터베이스 비밀번호를 재설정합니다. 4. 데이터베이스 관리자에게 문의하십시오.

1. 올바른 색인을 사용하여 스캔 한 데이터의 양을 줄임으로써 데이터 검색 속도를 높이십시오. 테이블 열을 여러 번 찾으면 해당 열에 대한 인덱스를 만듭니다. 귀하 또는 귀하의 앱이 기준에 따라 여러 열에서 데이터가 필요한 경우 복합 인덱스 2를 만듭니다. 2. 선택을 피하십시오 * 필요한 열만 선택하면 모든 원치 않는 열을 선택하면 더 많은 서버 메모리를 선택하면 서버가 높은 부하 또는 주파수 시간으로 서버가 속도가 느려지며, 예를 들어 Creation_at 및 Updated_at 및 Timestamps와 같은 열이 포함되어 있지 않기 때문에 쿼리가 필요하지 않기 때문에 테이블은 선택을 피할 수 없습니다.

Navicat Premium을 사용하여 데이터베이스 생성 : 데이터베이스 서버에 연결하고 연결 매개 변수를 입력하십시오. 서버를 마우스 오른쪽 버튼으로 클릭하고 데이터베이스 생성을 선택하십시오. 새 데이터베이스의 이름과 지정된 문자 세트 및 Collation의 이름을 입력하십시오. 새 데이터베이스에 연결하고 객체 브라우저에서 테이블을 만듭니다. 테이블을 마우스 오른쪽 버튼으로 클릭하고 데이터 삽입을 선택하여 데이터를 삽입하십시오.

다음 명령으로 MySQL 데이터베이스를보십시오. 서버에 연결하십시오. mysql -u username -p password run show database; 기존의 모든 데이터베이스를 가져 오려는 명령 데이터베이스 선택 : 데이터베이스 이름 사용; 보기 테이블 : 테이블 표시; 테이블 구조보기 : 테이블 이름을 설명합니다. 데이터보기 : 테이블 이름에서 *를 선택하십시오.

MariaDB 용 Navicat은 암호가 암호화 된 양식으로 저장되므로 데이터베이스 비밀번호를 직접 볼 수 없습니다. 데이터베이스 보안을 보장하려면 비밀번호를 재설정하는 세 가지 방법이 있습니다. Navicat을 통해 비밀번호를 재설정하고 복잡한 비밀번호를 설정하십시오. 구성 파일을 봅니다 (권장되지 않음, 위험이 높음). 시스템 명령 줄 도구를 사용하십시오 (권장되지 않으면 명령 줄 도구에 능숙해야 함).

MySQL에서 테이블을 복사하려면 새 테이블을 만들고, 데이터를 삽입하고, 외래 키 설정, 인덱스 복사, 트리거, 저장된 절차 및 기능이 필요합니다. 특정 단계에는 다음이 포함됩니다 : 동일한 구조를 가진 새 테이블 작성. 원래 테이블의 데이터를 새 테이블에 삽입하십시오. 동일한 외래 키 제약 조건을 설정하십시오 (원래 테이블에 하나가있는 경우). 동일한 색인을 만듭니다. 동일한 트리거를 만듭니다 (원래 테이블에 하나가있는 경우). 동일한 저장된 절차 또는 기능을 만듭니다 (원래 테이블이 사용되는 경우).
