【預告】5/13(一)起,第三階段頁面上方功能列以及下方資訊全面更換新版。 前往查看

教甄◆電腦科專業題庫下載題庫

上一題
7.以下何種運算可以將關聯式資料庫中兩個關聯表格 資料共同的部分篩選出來?
(A) UNION
(B) INNER JOIN
(C) SUM
(D) CARTESIAN PRODUCT


答案:登入後觀看
難度: 簡單

10
 【站僕】摩檸Morning:有沒有達人來解釋一下?
倒數 1天 ,已有 1 則答案
109考上台北市! 感恩阿 大四下 (2019/05/14):

首先大概是了解 inner 跟 outer 的差別,初學者大概都會使用 inner 這也是我們常常在用的 SQL,inner 就是 join 兩個資料表只顯示匹對的資料,另外一種 outer 就是不管是否有匹對,都會將資料顯示出來,又分為 LEFT, RIGHT, FULL join。 join 總共分為六種

01
02
03
04
05
06
Inner Join
Natural Join
Left Outer Join
Right Outer Join
Full Outer Join
Cross Join

1. Inner Join

01
02
03
04
--
-- 這算是最普通的 join 方法
--
SELECT a.*, b.* FROM `test1` as a, `test2` as b where a.id = b.id

2. Natural Join

01
02
03
--
-- 利用兩資料表相同欄位,自動連接上
SELECT a.*, b.* FROM `test1` as a NATURAL JOIN `test2` as b

3. Left, Right join

01
02
03
04
--
-- 這兩個其實是相同的,left join 就是顯示左邊表格所有資料,如果匹對沒有的話,就是顯示 NULL
-- right 則是相反
SELECT a.*, b.* FROM `test1` as a LEFT JOIN `test2` as b on a.id = b.id

4. Full Outer Join 這個可以利用 SQL UNION 處理掉,這只是聯集 Left 跟 Right 5. Cross Join 在 MySQL 語法裡面,它相同於 INNER Join,但是在標準 SQL 底下,它們不盡相同

01
02
SELECT * FROM t1 LEFT JOIN (t2, t3, t4)
                 ON (t2.a=t1.a AND t3.b=t1.b AND t4.c=t1.c)

同等於

01
02
SELECT * FROM t1 LEFT JOIN (t2 CROSS JOIN t3 CROSS JOIN t4)
                 ON (t2.a=t1.a AND t3.b=t1.b AND t4.c=t1.c)

資料來源:小惡魔 – 電腦技術 – 工作筆記 – AppleBOY

介紹一堆美食日記,生活日記,電腦筆記


0個讚
檢舉


7.以下何種運算可以將關聯式資料庫中兩個關聯表格 資料共同的部分篩選出來? ..-阿摩線上測驗