MySql FULL JOIN 即為 LEFT JOIN 與 RIGHT JOIN 的聯集,它會返回左右資料表中所有的紀錄,不論是否符合連接條件。

FULL JOIN 即為 LEFT JOIN 與 RIGHT JOIN 的聯集

FULL JOIN 即為 LEFT JOIN 與 RIGHT JOIN 的聯集,它會返回左右資料表中所有的紀錄,不論是否符合連接條件。

1
2
3
4
SELECT table_column1, table_column2...
FROM table_name1
FULL JOIN table_name2
ON table_name1.column_name=table_name2.column_name;

Example

1
2
3
4
SELECT customers.C_Id,customers.Name,customers.Address,customers.Phone,customers.Salary,orders.Order_No,orders.Product,orders.Product,orders.Quantity
FROM `customers`
RIGHT JOIN `orders`
ON customers.C_Id =orders.C_Id
LEFT JOIN 會返回左側資料表中所有資料列,就算沒有符合連接條件,而右側資料表中如果沒有匹配的資料值就會顯示為 NULL。

MySql CREATE INDEX 敘述句 (SQL CREATE INDEX Statement)

CREATE INDEX 語法 (SQL CREATE INDEX Syntax)

索引 (index)

1
CREATE INDEX index_name ON table_name (column_name);

建立多欄位索引 (Multiple-Column Index)

什麼時候建立多欄位索引比較合適?如果您常對一張資料表查詢 WHERE column_name1=’xxx’ AND column_name2=’yyy’,這時你就可以對 column_name1 及 column_name2 這兩個欄位建立一個共同索引。

1
CREATE INDEX index_name ON table_name (column_name1, column_name2...);

DROP INDEX 敘述句 (SQL DROP INDEX Statement)

移除索引

1
ALTER TABLE table_name DROP INDEX index_name;

MySql INNER JOIN And x

INNER JOIN (內部連接)

INNER JOIN (內部連接) 為等值連接,必需指定等值連接的條件,而查詢結果只會返回符合連接條件的資料。

1
2
3
4
5
6
7
8
9
10
SELECT table_column1, table_column2...
FROM table_name1
INNER JOIN table_name2
ON table_name1.column_name=table_name2.column_name;
//or
SELECT table_column1, table_column2...
FROM table_name1
INNER JOIN table_name2
USING (column_name);

Example

1
2
3
4
SELECT customers.C_Id,customers.Name,customers.Address,customers.Phone,customers.Salary,orders.Order_No,orders.Product,orders.Product,orders.Quantity
FROM `customers`
INNER JOIN `orders`
ON customers.C_Id =orders.C_Id

NATURAL JOIN

1
2
3
SELECT table_column1, table_column2...
FROM table_name1
NATURAL JOIN table_name2;

Example

1
SELECT customers.C_Id,customers.Name,customers.Address,customers.Phone,customers.Salary,orders.Order_No,orders.Product,orders.Product,orders.Quantity FROM `customers` NATURAL JOIN `orders`;

MySql INSERT INTO

INSERT INTO 語法 (SQL INSERT INTO Syntax)

1
2
3
4
5
INSERT INTO table_name (column1, column2, column3...)
VALUES (value1, value2, value3...);
//or
INSERT INTO table_name
VALUES (value1, value2, value3...);
INSERT INTO例子
1
2
3
4
5
6
INSERT INTO customers (C_Id, Name, City, Address, Phone)
VALUES (3, '李三', '高雄縣', 'ZZ路300號', '07-12345678');
or
INSERT INTO customers
VALUES (3, '李三', '高雄縣', 'ZZ路300號', '07-12345678');

MySql INTERSECT 運算子 (SQL INTERSECT Operator)

INTERSECT 語法 (SQL INTERSECT Syntax)

相對於 UNION 像是 OR (聯集),INTERSECT 運算子則像是 AND (交集),如果紀錄存在於第一個查詢結果集內同時亦存在於第二個查詢結果集內時,才會被取出。

1
2
3
SELECT column_name(s) FROM table_name1
INTERSECT
SELECT column_name(s) FROM table_name2;

查出在台灣地區及中國大陸地區皆有銷售的產品類別的資料

1
2
3
SELECT P_Name FROM `products_taiwan`
INTERSECT
SELECT P_Name FROM `products_china`;
*MySQL 目前還不支援 INTERSECT。

MySql LEFT JOIN 關鍵字 (SQL LEFT JOIN Keyword) - 左外部連接

LEFT JOIN 可以用來建立左外部連接

LEFT JOIN 可以用來建立左外部連接,查詢的 SQL 敘述句 LEFT JOIN 左側資料表 (table_name1) 的所有記錄都會加入到查詢結果中,即使右側資料表 (table_name2) 中的連接欄位沒有符合的值也一樣。

1
2
3
4
SELECT table_column1, table_column2...
FROM table_name1
LEFT JOIN table_name2
ON table_name1.column_name=table_name2.column_name;

Example

1
2
3
4
SELECT customers.C_Id,customers.Name,customers.Address,customers.Phone,customers.Salary,orders.Order_No,orders.Product,orders.Product,orders.Quantity
FROM `customers`
LEFT JOIN `orders`
ON customers.C_Id =orders.C_Id
LEFT JOIN 會返回左側資料表中所有資料列,就算沒有符合連接條件,而右側資料表中如果沒有匹配的資料值就會顯示為 NULL。

MySql SELECT WHERE LIKE

(NOT) LIKE 運算子 (SQL (NOT) LIKE Operator)

LIKE 運算子搭配 WHERE 子句可以依一特定模式 (Pattern) 為條件來搜尋資料表中的特定資料。

1
2
3
SELECT table_column1, table_column2, table_column3...
FROM table_name
WHERE column_name LIKE pattern;

例如,找住在台北市的客戶:

1
SELECT * FROM `customers` WHERE City LIKE '台北%';

NOT LIKE

相反的,NOT LIKE 就是不包含在條件裡的的資料我通通要了,如上例多加上 NOT:

1
SELECT * FROM `customers` WHERE City NOT LIKE '台北%';

MySql MINUS 運算子 (SQL MINUS Operator)

MINUS 運算子 (SQL MINUS Operator)

當 MINUS 運算子結合了兩個 SELECT 查詢語句,它會將 (第一個查詢結果集) 減去 (同時存在於第一個查詢結果集與第二個查詢結果集的資料紀錄),然後返回其結果。

1
2
3
SELECT column_name(s) FROM table_name1
MINUS
SELECT column_name(s) FROM table_name2;
1
SELECT P_Name FROM `products_taiwan` MINUS SELECT P_Name FROM `products_china`;

**MySQL 目前還不支援 MINUS。

MySql ORDER BY

ORDER BY 關鍵字 (SQL ORDER BY Keyword)

我們可以將 SELECT 取得的資料集依某欄位來作排序,而排序分別可以由小至大 (ascending; 預設),或由大至小 (descending)。
ORDER BY 語法 (SQL ORDER BY Syntax)

1
2
3
SELECT table_column1, table_column2...
FROM table_name
ORDER BY column_name1 ASC|DESC, column_name2 ASC|DESC...

Example 舉例

1
SELECT `C_Id`, `Name`, `City`, `Address`, `Phone` FROM `customers` ORDER BY `Name`;
1
SELECT `C_Id`, `Name`, `City`, `Address`, `Phone` FROM `customers` ORDER BY `City`;
1
SELECT `C_Id`, `Name`, `City`, `Address`, `Phone` FROM `customers` ORDER BY `Address`;
1
SELECT `C_Id`, `Name`, `City`, `Address`, `Phone` FROM `customers` ORDER BY `Address`;
1
SELECT `C_Id`, `Name`, `City`, `Address`, `Phone` FROM `customers` ORDER BY `Phone`;
ORDER BY 查詢用法 (Example) 從下面的 employees 資料表中取出所有員工的資料並依職稱來作排序 (即字母順序):
1
SELECT * FROM `customers` ORDER BY `City`;

若語句中沒加上 ASC 或 DESC 關鍵字,預設默認為 ASC。