>  기사  >  데이터 베이스  >  MySQL 데이터 쿼리 연결 쿼리

MySQL 데이터 쿼리 연결 쿼리

coldplay.xixi
coldplay.xixi앞으로
2021-03-15 09:05:473178검색

MySQL 데이터 쿼리 연결 쿼리

  • 연결 관계는 관계형 데이터베이스 모델의 주요 특징입니다. 가장 중요한 쿼리이기도 하며 주로 내부 조인, 외부 조인 등이 포함됩니다.
  • 연결 연산자를 통해 여러 테이블 쿼리를 구현할 수 있습니다.
  • 관계형 데이터베이스 관리 시스템에서는 테이블을 생성할 때 각 데이터 간의 관계를 결정할 필요가 없으며 엔터티의 모든 정보가 하나의 테이블에 저장되는 경우가 많습니다. 데이터를 쿼리할 때 연결 작업을 통해 여러 테이블에 저장된 다양한 엔터티에 대한 정보를 쿼리합니다. 두 개 이상의 테이블에 동일한 의미를 가진 필드가 있는 경우 이러한 필드를 사용하여 다른 테이블에 대한 조인 쿼리를 수행할 수 있습니다.

다음은 여러 테이블 간의 세 가지 연결 방법을 소개합니다.

(1) 내부 조인 쿼리
(2) 외부 조인 쿼리
(3) 복합 조건부 조인 쿼리

(무료 학습 권장 사항: mysql 비디오 자습서 )


(1), 내부 조인 쿼리(inner Join)
  • 내부 조인은 비교 연산자를 사용하여 테이블 간의 특정(특정) 열 데이터를 비교하고 조인 조건에 일치하는 이 테이블의 데이터를 나열합니다. 데이터 행이 새 레코드를 형성합니다. 즉, 내부 조인 쿼리에서는 조건을 충족하는 레코드만 결과 관계에 나타날 수 있습니다.

시연을 위해 아래의 데이터 테이블 공급자를 만듭니다.

mysql> create table suppliers    -> (
    -> s_id int not null auto_increment,
    -> s_name char(50) not null,
    -> s_city char(50) null,
    -> s_zip char(10) null,
    -> s_call char(50) not null,
    -> primary key(s_id)
    -> );Query OK, 0 rows affected (0.17 sec)mysql> insert into suppliers(s_id,s_name,s_city,s_zip,s_call)
    -> values(101,'FastFruit Inc.','Tianjin','300000','48075'),
    -> (102,'LT Supplies','Chongqing','400000','44333'),
    -> (103,'ACME','Shanghai','200000','90046'),
    -> (104,'FNK Inc.','Zhongshan','528437','11111'),
    -> (105,'Good Set','Taiyuan','030000','22222'),
    -> (106,'Just Eat Ours','Beijing','010','45678'),
    -> (107,'DK Inc','Zhengzhou','450000','33332');Query OK, 7 rows affected (0.07 sec)Records: 7  Duplicates: 0  Warnings: 0

[예제 1] 과일 테이블과 공급자 테이블 사이에 내부 조인 쿼리를 사용합니다.

mysql> desc fruits;+---------+--------------+------+-----+---------+-------+| Field   | Type         | Null | Key | Default | Extra |+---------+--------------+------+-----+---------+-------+| f_id    | char(10)     | NO   | PRI | NULL    |       || s_id    | int(11)      | NO   |     | NULL    |       || f_name  | char(255)    | NO   |     | NULL    |       || f_price | decimal(8,2) | NO   |     | NULL    |       |+---------+--------------+------+-----+---------+-------+4 rows in set (0.06 sec)mysql> desc suppliers;+--------+----------+------+-----+---------+----------------+| Field  | Type     | Null | Key | Default | Extra          |+--------+----------+------+-----+---------+----------------+| s_id   | int(11)  | NO   | PRI | NULL    | auto_increment || s_name | char(50) | NO   |     | NULL    |                || s_city | char(50) | YES  |     | NULL    |                || s_zip  | char(10) | YES  |     | NULL    |                || s_call | char(50) | NO   |     | NULL    |                |+--------+----------+------+-----+---------+----------------+5 rows in set (0.00 sec)

fruits 테이블과 공급자 테이블 모두 s_id라는 데이터 유형 필드가 동일하고, 두 테이블이 s_id 필드를 통해 연결되어 있는 것을 볼 수 있습니다.

다음으로, 과일 테이블에서 f_name 및 f_price 필드를 쿼리하고, 공급자 테이블에서 s_id 및 s_name을 쿼리합니다. SQL 문은 다음과 같습니다.

mysql> select suppliers.s_id,s_name,f_name,f_price    -> from fruits,suppliers    -> where fruits.s_id=suppliers.s_id;+------+----------------+------------+---------+| s_id | s_name         | f_name     | f_price |+------+----------------+------------+---------+|  104 | FNK Inc.       | lemon      |    6.40 ||  101 | FastFruit Inc. | apple      |    5.20 ||  103 | ACME           | apricot    |    2.20 ||  101 | FastFruit Inc. | blackberry |   10.20 ||  104 | FNK Inc.       | berry      |    7.60 ||  107 | DK Inc         | xxxx       |    3.60 ||  102 | LT Supplies    | orange     |   11.20 ||  105 | Good Set       | melon      |    8.20 ||  101 | FastFruit Inc. | cherry     |    3.20 ||  106 | Just Eat Ours  | mango      |   15.70 ||  105 | Good Set       | xbabay     |    2.60 ||  105 | Good Set       | xxtt       |   11.60 ||  103 | ACME           | coconut    |    9.20 ||  102 | LT Supplies    | banana     |   10.30 ||  102 | LT Supplies    | grape      |    5.30 ||  107 | DK Inc         | xbabay     |    3.60 |+------+----------------+------------+---------+16 rows in set (0.00 sec)
  • 참고: 과일 테이블과 공급자 테이블이 동일한 필드를 갖기 때문입니다. s_id이므로 비교에서 테이블 이름을 완전히 한정해야 하는 경우 형식은 "테이블 이름.열 이름"입니다. s_id만 제공되면 MySQL은 그것이 참조하는 항목을 알 수 없으며 오류 메시지를 반환합니다.

[예제 2] 과일 테이블과 공급자 테이블 사이에서 내부 조인 쿼리를 위해 내부 조인 구문을 사용합니다. SQL 문은 다음과 같습니다.

mysql> select suppliers.s_id,s_name,f_name,f_price    -> from fruits inner join suppliers    -> on fruits.s_id = suppliers.s_id;+------+----------------+------------+---------+| s_id | s_name         | f_name     | f_price |+------+----------------+------------+---------+|  104 | FNK Inc.       | lemon      |    6.40 ||  101 | FastFruit Inc. | apple      |    5.20 ||  103 | ACME           | apricot    |    2.20 ||  101 | FastFruit Inc. | blackberry |   10.20 ||  104 | FNK Inc.       | berry      |    7.60 ||  107 | DK Inc         | xxxx       |    3.60 ||  102 | LT Supplies    | orange     |   11.20 ||  105 | Good Set       | melon      |    8.20 ||  101 | FastFruit Inc. | cherry     |    3.20 ||  106 | Just Eat Ours  | mango      |   15.70 ||  105 | Good Set       | xbabay     |    2.60 ||  105 | Good Set       | xxtt       |   11.60 ||  103 | ACME           | coconut    |    9.20 ||  102 | LT Supplies    | banana     |   10.30 ||  102 | LT Supplies    | grape      |    5.30 ||  107 | DK Inc         | xbabay     |    3.60 |+------+----------------+------------+---------+16 rows in set (0.00 sec)
  • where 절을 사용하여 연결을 정의하는 것이 비교적 간단하고 명확합니다. 조건 및 내부 조인 구문은 ANSI입니다. 내부 조인 연결 구문을 사용하는 SQL의 표준 사양은 연결 조건을 잊어버리지 않도록 보장할 수 있으며 where 절은 어느 시점에서 쿼리 성능에 영향을 미칩니다.

조인 쿼리에 포함된 두 테이블이 동일한 테이블인 경우 이러한 유형의 쿼리를 셀프 조인 쿼리라고 합니다. Self-Join은 특별한 내부 조인으로 서로 연결된 테이블이 물리적으로는 동일한 테이블이지만 논리적으로는 두 개의 테이블로 분할될 수 있다는 의미입니다.

[예시 3] f_id='a1'를 제공하는 과일 공급자가 제공하는 과일 유형을 쿼리합니다. SQL 문은 다음과 같습니다. f_id='a1'的水果供应商提供的水果种类,SQL语句如下:

mysql> select f1.f_id,f1.f_name    -> from fruits as f1,fruits as f2    -> where f1.s_id =f2.s_id and f2.f_id ='a1';+------+------------+| f_id | f_name     |+------+------------+| a1   | apple      || b1   | blackberry || c0   | cherry     |+------+------------+3 rows in set (0.00 sec)

(2)、外连接查询
  • 外连接查询将查询多个表中相关联的行。
  • 内连接时,返回查询结果集合中的仅是符合查询条件和连接条件的行。但有时候需要包含没有关联的行中数据,即返回查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外连接或左连接)、右表(右外连接或右连接)或两个边接表(全外连接)中的所有数据行。外连接分为左外连接或左连接和右外连接或右连接:

①左连接:返回包括左表中的所有记录和右表中连接字段相等的记录。
②右连接:返回包括右表中的记录和左表中连接字段相等的记录。

1.左连接left join

首先创建表orders,SQL语句如下;

mysql> create table orders    -> (
    -> o_num int not null auto_increment,
    -> o_date datetime not null,
    -> c_id int not null,
    -> primary key (o_num)
    -> );Query OK, 0 rows affected (0.11 sec)mysql> insert into orders(o_num,o_date,c_id)
    -> values(30001,'2008-09-01',10001),
    -> (30002,'2008-09-12',10003),
    -> (30003,'2008-09-30',10004),
    -> (30004,'2008-10-03',10005),
    -> (30005,'2008-10-08',10001);Query OK, 5 rows affected (0.06 sec)Records: 5  Duplicates: 0  Warnings: 0

【例】在customers表和orders表中,查询所有客户,包括没有订单的客户,SQL语句如下:

mysql> select * from customers;+-------+----------+---------------------+---------+--------+-----------+-------------------+| c_id  | c_name   | c_address           | c_city  | c_zip  | c_contact | c_email           |+-------+----------+---------------------+---------+--------+-----------+-------------------+| 10001 | redhool  | 200 Street          | Tianjin | 300000 | LiMing    | LMing@163.com     || 10002 | Stars    | 333 Fromage Lane    | Dalian  | 116000 | Zhangbo   | Jerry@hotmail.com || 10003 | Netbhood | 1 Sunny Place       | Qingdao | 266000 | LuoCong   | NULL              || 10004 | JOTO     | 829 Riverside Drive | Haikou  | 570000 | YangShan  | sam@hotmail.com   |+-------+----------+---------------------+---------+--------+-----------+-------------------+4 rows in set (0.00 sec)mysql> select * from orders;+-------+---------------------+-------+| o_num | o_date              | c_id  |+-------+---------------------+-------+| 30001 | 2008-09-01 00:00:00 | 10001 || 30002 | 2008-09-12 00:00:00 | 10003 || 30003 | 2008-09-30 00:00:00 | 10004 || 30004 | 2008-10-03 00:00:00 | 10005 || 30005 | 2008-10-08 00:00:00 | 10001 |+-------+---------------------+-------+5 rows in set (0.00 sec)mysql>  select customers.c_id , orders.o_num    -> from customers left outer join orders    -> on customers.c_id = orders.c_id;+-------+-------+| c_id  | o_num |+-------+-------+| 10001 | 30001 || 10003 | 30002 || 10004 | 30003 || 10001 | 30005 || 10002 |  NULL |+-------+-------+5 rows in set (0.00 sec)

2.右连接right join

mysql> select customers.c_id, orders.o_num    -> from customers right outer join orders    -> on customers.c_id = orders.c_id;+-------+-------+| c_id  | o_num |+-------+-------+| 10001 | 30001 || 10003 | 30002 || 10004 | 30003 ||  NULL | 30004 || 10001 | 30005 |+-------+-------+5 rows in set (0.00 sec)
(2 ), 외부 연결 쿼리
  • 외부 조인 쿼리는 여러 테이블의 관련 행을 쿼리합니다.

Inner Join을 수행하면 쿼리 조건과 연결 조건을 만족하는 쿼리 결과 집합의 행만 반환됩니다. 그러나 때로는 관련되지 않은 행의 데이터를 포함해야 하는 경우도 있습니다. 즉, 반환된 쿼리 결과 집합에는 조인 조건을 충족하는 행뿐만 아니라 왼쪽 테이블(왼쪽 외부 조인 또는 왼쪽 조인), 오른쪽 테이블(오른쪽 테이블)도 포함됩니다. 외부 조인 또는 오른쪽 조인)) 또는 두 에지 테이블의 모든 데이터 행(완전 외부 조인). 외부 조인은 왼쪽 외부 조인 또는 왼쪽 조인과 오른쪽 외부 조인 또는 오른쪽 조인으로 구분됩니다.


①왼쪽 조인: 왼쪽 테이블의 모든 레코드를 반환하고 오른쪽 테이블의 등호 조인 필드가 있는 레코드를 반환합니다.
②오른쪽 조인: 왼쪽 테이블의 조인 필드와 동일한 오른쪽 테이블의 레코드를 포함한 레코드를 반환합니다.
  • 1. Left Join left Join
먼저 주문 테이블을 생성하면 SQL 문은 다음과 같습니다.

mysql> select customers.c_id,orders.o_num    -> from customers inner join orders    -> on customers.c_id = orders.c_id and customers.c_id = 10001;+-------+-------+| c_id  | o_num |+-------+-------+| 10001 | 30001 || 10001 | 30005 |+-------+-------+2 rows in set (0.00 sec)
[예제] 고객 테이블과 주문 테이블에서 고객을 포함한 모든 고객을 쿼리합니다. 순서 없이 SQL 문은 다음과 같습니다.

mysql> select suppliers.s_id,s_name,f_name,f_price    -> from fruits inner join suppliers    -> on fruits.s_id = suppliers.s_id    -> order by fruits.s_id;+------+----------------+------------+---------+| s_id | s_name         | f_name     | f_price |+------+----------------+------------+---------+|  101 | FastFruit Inc. | apple      |    5.20 ||  101 | FastFruit Inc. | blackberry |   10.20 ||  101 | FastFruit Inc. | cherry     |    3.20 ||  102 | LT Supplies    | orange     |   11.20 ||  102 | LT Supplies    | banana     |   10.30 ||  102 | LT Supplies    | grape      |    5.30 ||  103 | ACME           | apricot    |    2.20 ||  103 | ACME           | coconut    |    9.20 ||  104 | FNK Inc.       | lemon      |    6.40 ||  104 | FNK Inc.       | berry      |    7.60 ||  105 | Good Set       | melon      |    8.20 ||  105 | Good Set       | xbabay     |    2.60 ||  105 | Good Set       | xxtt       |   11.60 ||  106 | Just Eat Ours  | mango      |   15.70 ||  107 | DK Inc         | xxxx       |    3.60 ||  107 | DK Inc         | xbabay     |    3.60 |+------+----------------+------------+---------+16 rows in set (0.00 sec)
2. 오른쪽 조인 오른쪽 조인

오른쪽 조인은 왼쪽 조인의 역조인이며 오른쪽 테이블의 모든 행을 반환합니다. . 오른쪽 테이블의 행과 왼쪽 테이블의 일치하는 행이 없으면 왼쪽 테이블은 null 값을 반환합니다. [예시] 고객 테이블과 주문 테이블에서 고객이 없는 주문을 포함한 모든 주문을 쿼리할 때, SQL 문은 다음과 같습니다. rrreee(3), 복합 조건 연결 쿼리

복합 조건 연결 쿼리 연결 중입니다. 쿼리 과정에서 쿼리 결과를 제한하는 필터링 조건이 추가되어 쿼리 결과가 더욱 정확해집니다. 🎜🎜🎜[예제 1] 고객 테이블과 주문 테이블에서 내부 조인 구문을 사용하여 고객 테이블을 쿼리하여 ID 10001인 고객의 주문 정보를 요약합니다. SQL 문은 다음과 같습니다. 🎜rrreee🎜[예 2] 과일 테이블과 공급업체 테이블 시간 사이에 내부 조인 구문을 사용하여 내부 조인 쿼리를 수행하고 쿼리 결과를 정렬합니다. 🎜(동영상)🎜🎜🎜

위 내용은 MySQL 데이터 쿼리 연결 쿼리의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 csdn.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제