MySQL笔记之连接查询详解_MySQL
bitsCN.com
连接查询是将两个或两个以上的表按某个条件连接起来,从中选取需要的数据
当不同的表中存在表示相同意义的字段时,可以通过该字段来连接这几张表
参考表:employee
参考表:department
可以看到,上面两张表都有同一个字段d_id
当两张表含有相同意义的字段(可以不同名)时就可以进行连接查询
内连接查询mysql> SELECT num, name, employee.d_id, sex, d_name, function
-> FROM employee, department
-> WHERE employee.d_id=department.d_id;
+------+--------+------+------+-----------+--------------+
| num | name | d_id | sex | d_name | function |
+------+--------+------+------+-----------+--------------+
| 1 | 张三 | 1001 | 男 | 科技部 | 研发产品 |
| 2 | 李四 | 1001 | 女 | 科技部 | 研发产品 |
| 3 | 王五 | 1002 | 男 | 生产部 | 生产产品 |
+------+--------+------+------+-----------+--------------+
rows in set (0.00 sec)
内连接查询只会查询完全匹配的结果,此处使用d_id字段进行连接
下面的表中也同样使用这一字段
外连接查询
外查询也需要通过指定字段来进行连接,当该字段取值相等时,可以查询出该记录
而且,该字段取值不相等的记录也可以查询出来
外连接查询包括左连接查询和右连接查询
左连接查询
mysql> SELECT num, name, employee.d_id, d_name, function
-> FROM employee LEFT JOIN department
-> ON employee.d_id=department.d_id;
+------+--------+------+-----------+--------------+
| num | name | d_id | d_name | function |
+------+--------+------+-----------+--------------+
| 1 | 张三 | 1001 | 科技部 | 研发产品 |
| 2 | 李四 | 1001 | 科技部 | 研发产品 |
| 3 | 王五 | 1002 | 生产部 | 生产产品 |
| 4 | Aric | 1004 | NULL | NULL |
+------+--------+------+-----------+--------------+
rows in set (0.00 sec)
此处不仅查询出了两表中d_id字段相匹配的信息
并且通过LEFT JOIN查询出了employee表中所有指定字段的信息
由于Aric没有对应d_name和function信息,所以显示null
右连接查询
mysql> SELECT num, name, employee.d_id, d_name, function
-> FROM employee RIGHT JOIN department
-> ON employee.d_id=department.d_id;
+------+--------+------+-----------+--------------+
| num | name | d_id | d_name | function |
+------+--------+------+-----------+--------------+
| 1 | 张三 | 1001 | 科技部 | 研发产品 |
| 2 | 李四 | 1001 | 科技部 | 研发产品 |
| 3 | 王五 | 1002 | 生产部 | 生产产品 |
| NULL | NULL | NULL | 销售部 | 策划销售 |
+------+--------+------+-----------+--------------+
rows in set (0.00 sec)
与上面相反,这里查询出了匹配的信息和department表中的所有指定字段的信息
但是由于employee表中部分字段没有对应,因此最后一行记录有显示NULL
复合条件连接查询
mysql> SELECT num, name, employee.d_id, sex, age, address
-> FROM employee, department
-> WHERE employee.d_id=department.d_id
-> AND age>=25;
+------+--------+------+------+------+-------------+
| num | name | d_id | sex | age | address |
+------+--------+------+------+------+-------------+
| 1 | 张三 | 1001 | 男 | 26 | 3号楼5层 |
| 3 | 王五 | 1002 | 男 | 25 | 5号楼1层 |
+------+--------+------+------+------+-------------+
rows in set (0.00 sec)
复合条件连接查询是在进行连接查询的时候加入限制条件,此处的age>=25便是
通常情况下,限制条件越多,查询越精确,限制条件可用AND累加
此外,还可以用复合条件进行ORDER BY 排序
tips:连接查询中使用最多的是内连接查询,而外连接查询使用频率较低
bitsCN.com
핫 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)

뜨거운 주제











이 기사는 Docker에서 MySQL 메모리 사용을 최적화합니다. 모니터링 기술 (Docker Stats, Performance Schema, 외부 도구) 및 구성 전략에 대해 설명합니다. 여기에는 Docker 메모리 제한, 스와핑 및 CGroups와 함께 포함됩니다

이 기사에서는 MySQL의 "공유 라이브러리를 열 수 없음"오류를 다룹니다. 이 문제는 MySQL이 필요한 공유 라이브러리 (.so/.dll 파일)를 찾을 수 없음에서 비롯됩니다. 솔루션은 시스템 패키지 M을 통한 라이브러리 설치 확인과 관련이 있습니다.

이 기사는 MySQL의 Alter Table 문을 사용하여 열 추가/드롭 테이블/열 변경 및 열 데이터 유형 변경을 포함하여 테이블을 수정하는 것에 대해 설명합니다.

이 기사는 Linux에 MySQL을 직접 설치하는 것과 Phpmyadmin이없는 Podman 컨테이너 사용을 비교합니다. 각 방법에 대한 설치 단계에 대해 자세히 설명하면서 Podman의 격리, 이식성 및 재현성의 장점을 강조하지만 또한

이 기사는 자체 포함 된 서버리스 관계형 데이터베이스 인 SQLITE에 대한 포괄적 인 개요를 제공합니다. SQLITE의 장점 (단순성, 이식성, 사용 용이성) 및 단점 (동시성 제한, 확장 성 문제)에 대해 자세히 설명합니다. 기음

이 안내서는 Homebrew를 사용하여 MacOS에 여러 MySQL 버전을 설치하고 관리하는 것을 보여줍니다. 홈 브루를 사용하여 설치를 분리하여 갈등을 방지하는 것을 강조합니다. 이 기사에는 설치, 서비스 시작/정지 서비스 및 Best Pra에 대해 자세히 설명합니다

기사는 인증서 생성 및 확인을 포함하여 MySQL에 대한 SSL/TLS 암호화 구성에 대해 설명합니다. 주요 문제는 자체 서명 인증서의 보안 영향을 사용하는 것입니다. [문자 수 : 159]

기사는 MySQL Workbench 및 Phpmyadmin과 같은 인기있는 MySQL GUI 도구에 대해 논의하여 초보자 및 고급 사용자를위한 기능과 적합성을 비교합니다. [159 자].
