MySQL多表聯集查詢sql語句

來源:互聯網
上載者:User


最簡的一種聯集查詢

 代碼如下 複製代碼

SELECT * FROM table1 n, table2 i WHERE n.itemid = i.itemid



推廣地點表promotion_addr欄位:name,id

電話報竣表unicom_record欄位:date, sheet_id(關聯sheet表id)

報單表sheet欄位:id,promotion_addr_id(關聯promotion_addr表id)

要求統計某個月已報竣各推廣地點的推廣個數;

 

 代碼如下 複製代碼

 

SELECT
p.name, count(*)
FROM
unicom_record AS ur

Left Join sheet AS s ON ur.sheet_id = s.id
Left Join promotion_addr AS p ON s.promotion_addr_id = p.id
WHERE
ur.status =? ‘COMPLETE’ AND
ur.`date` >=? ’2010-03-01′ AND
ur.`date` <? ’2010-04-01′
GROUP BY
p.id

(或使用between and語句)


內串連INNER JOIN


join_table: table_reference [INNER | CROSS] JOIN table_factor [join_condition]

MySQL中的外串連

select id, name, action from user as u  left join user_action a on u.id = a.user_id 


還是先 Create table 吧

create table emp(
id int not null primary key,
name varchar(10)
);

create table emp_dept(
dept_id varchar(4) not null,
emp_id int not null,
emp_name varchar(10),
primary key (dept_id,emp_id));

insert into emp() values
(1,”Dennis-1″),
(2,”Dennis-2″),
(3,”Dennis-3″),
(4,”Dennis-4″),
(5,”Dennis-5″),
(6,”Dennis-6″),
(7,”Dennis-7″),
(8,”Dennis-8″),
(9,”Dennis-9″),
(10,”Dennis-10″);

insert into emp_dept() values
(“R&D”,1,”Dennis-1″),
(“DEv”,2,”Dennis-2″),
(“R&D”,3,”Dennis-3″),
(“Test”,4,”Dennis-4″),
(“Test”,5,”Dennis-5″);

>> left join
————-

 代碼如下 複製代碼
select a.id,a.name,b.dept_id
from emp a left join emp_dept b on (a.id=b.emp_id);

# 挑出左邊的 table emp 中的所有資料,即使 emp_dept 中沒有的資料也挑出來,沒有的就用 NULL   來顯示,
# 也即顯示資料是以左邊的 table emp 中的資料為基礎

 代碼如下 複製代碼
mysql> select a.id,a.name,b.dept_id
-> from emp a left join emp_dept b on (a.id=b.emp_id);

+—-+———–+———+
| id | name      | dept_id |
+—-+———–+———+
|  1 | Dennis-1  | R&D     |
|  2 | Dennis-2  | DEv     |
|  3 | Dennis-3  | R&D     |
|  4 | Dennis-4  | Test    |
|  5 | Dennis-5  | Test    |
|  6 | Dennis-6  | NULL    |
|  7 | Dennis-7  | NULL    |
|  8 | Dennis-8  | NULL    |
|  9 | Dennis-9  | NULL    |
| 10 | Dennis-10 | NULL    |
+—-+———–+———+
# 挑出 table emp 中有而 table emp_dept 中沒有的人員資料

 代碼如下 複製代碼

select a.id,a.name,b.dept_id
from emp a left join emp_dept b on (a.id=b.emp_id)
where b.dept_id IS NULL;

mysql> select a.id,a.name,b.dept_id
-> from emp a left join emp_dept b on (a.id=b.emp_id)
-> where b.dept_id IS NULL;

+—-+———–+———+
| id | name      | dept_id |
+—-+———–+———+
|  6 | Dennis-6  | NULL    |
|  7 | Dennis-7  | NULL    |
|  8 | Dennis-8  | NULL    |
|  9 | Dennis-9  | NULL    |
| 10 | Dennis-10 | NULL    |
+—-+———–+———+

# 把 table emp_dept 放在左邊的情形(當然以 emp_dept 中的資料為基礎來顯示資料,emp 中比emp_dept 中多的資料也就不會顯示出來了):

 代碼如下 複製代碼
select a.id,a.name,b.dept_id
from emp_dept b left join emp a on (a.id=b.emp_id);
mysql> select a.id,a.name,b.dept_id
-> from emp_dept b left join emp a on (a.id=b.emp_id);

+——+———-+———+
| id   | name     | dept_id |
+——+———-+———+
|    2 | Dennis-2 | DEv     |
|    1 | Dennis-1 | R&D     |
|    3 | Dennis-3 | R&D     |
|    4 | Dennis-4 | Test    |
|    5 | Dennis-5 | Test    |
+——+———-+———+

>> right join
—————

 代碼如下 複製代碼
select a.id,a.name,b.dept_id
from emp a right join emp_dept b on (a.id=b.emp_id);

# 挑資料時以右邊 table emp_dept 中的資料為基礎來顯示資料

 代碼如下 複製代碼

mysql> select a.id,a.name,b.dept_id
-> from emp a right join emp_dept b on (a.id=b.emp_id);

+——+———-+———+
| id   | name     | dept_id |
+——+———-+———+
|    2 | Dennis-2 | DEv     |
|    1 | Dennis-1 | R&D     |
|    3 | Dennis-3 | R&D     |
|    4 | Dennis-4 | Test    |
|    5 | Dennis-5 | Test    |
+——+———-+———+
5 rows in set (0.00 sec)

# 我們再把 table 的位置交換一下,再用 right join 試試

 代碼如下 複製代碼

select a.id,a.name,b.dept_id
from emp_dept b right join emp a on (a.id=b.emp_id);

mysql> select a.id,a.name,b.dept_id
-> from emp_dept b right join emp a on (a.id=b.emp_id);

+—-+———–+———+
| id | name      | dept_id |
+—-+———–+———+
|  1 | Dennis-1  | R&D     |
|  2 | Dennis-2  | DEv     |
|  3 | Dennis-3  | R&D     |
|  4 | Dennis-4  | Test    |
|  5 | Dennis-5  | Test    |
|  6 | Dennis-6  | NULL    |
|  7 | Dennis-7  | NULL    |
|  8 | Dennis-8  | NULL    |
|  9 | Dennis-9  | NULL    |
| 10 | Dennis-10 | NULL    |
+—-+———–+———+

# 是不是和 left join 一樣了?

>> direct join
————–
# 如果用right join 同不用 Join 直接挑資料是相同的,它等介於以下的指令

 代碼如下 複製代碼

select a.id,a.name,b.dept_id
from emp a ,emp_dept b
where a.id=b.emp_id;

mysql> select a.id,a.name,b.dept_id
-> from emp a ,emp_dept b
-> where a.id=b.emp_id;

+—-+———-+———+
| id | name     | dept_id |
+—-+———-+———+
|  2 | Dennis-2 | DEv     |
|  1 | Dennis-1 | R&D     |
|  3 | Dennis-3 | R&D     |
|  4 | Dennis-4 | Test    |
|  5 | Dennis-5 | Test    |
+—-+———-+———+

怎樣,弄明白了嗎?

Enjoy it!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.