SQLite Unions 子句  [ 合併(串聯) 1個以上的查詢結果 ]

SQLite Unions 子句  [ 合併(串聯) 1個以上的查詢結果 ]

SQLite Unions 子句  [ 合併(串聯) 1個以上的查詢結果 ]

 

 

資料來源: http://www.runoob.com/sqlite/sqlite-unions-clause.html

 

 

SQLite UNION 子句/運算子用於合併兩個或多個 SELECT 語句的結果,不返回任何重複的行。

為了使用 UNION,每個 SELECT 被選擇的列數必須是相同的,相同數目的列運算式,相同的資料類型,並確保它們有相同的順序,但它們不必具有相同的長度。

語法

UNION 的基本語法如下:

SELECT column1 [, column2 ]

FROM table1 [, table2 ]

[WHERE condition]

 

UNION

 

SELECT column1 [, column2 ]

FROM table1 [, table2 ]

[WHERE condition]

這裡給定的條件根據需要可以是任何運算式。

實例

假設有下面兩個表,(1COMPANY 表如下所示:

sqlite> select * from COMPANY;

ID          NAME                  AGE         ADDRESS     SALARY

———-  ——————–  ———-  ———-  ———-

1           Paul                  32          California  20000.0

2           Allen                 25          Texas       15000.0

3           Teddy                 23          Norway      20000.0

4           Mark                  25          RichMond   65000.0

5           David                 27          Texas       85000.0

6           Kim                   22          SouthHall  45000.0

7           James                 24          Houston     10000.0

2)另一個表是 DEPARTMENT,如下所示:

ID          DEPT                  EMP_ID

———-  ——————–  ———-

1           IT Billing            1

2           Engineering           2

3           Finance               7

4           Engineering           3

5           Finance               4

6           Engineering           5

7           Finance               6

現在,讓我們使用 SELECT 語句及 UNION 子句來連接兩個表,如下所示:

sqlite> SELECT EMP_ID, NAME, DEPT FROM COMPANY INNER JOIN DEPARTMENT

        ON COMPANY.ID = DEPARTMENT.EMP_ID

   UNION

     SELECT EMP_ID, NAME, DEPT FROM COMPANY LEFT OUTER JOIN DEPARTMENT

        ON COMPANY.ID = DEPARTMENT.EMP_ID;

這將產生以下結果:

EMP_ID      NAME                  DEPT

———-  ——————–  ———-

1           Paul                  IT Billing

2           Allen                 Engineerin

3           Teddy                 Engineerin

4           Mark                  Finance

5           David                 Engineerin

6           Kim                   Finance

7           James                 Finance

UNION ALL 子句

UNION ALL 運算子用於結合兩個 SELECT 語句的結果,包括重複行。

適用於 UNION 的規則同樣適用於 UNION ALL 運算子。

語法

UNION ALL 的基本語法如下:

SELECT column1 [, column2 ]

FROM table1 [, table2 ]

[WHERE condition]

 

UNION ALL

 

SELECT column1 [, column2 ]

FROM table1 [, table2 ]

[WHERE condition]

這裡給定的條件根據需要可以是任何運算式。

實例

現在,讓我們使用 SELECT 語句及 UNION ALL 子句來連接兩個表,如下所示:

sqlite> SELECT EMP_ID, NAME, DEPT FROM COMPANY INNER JOIN DEPARTMENT

        ON COMPANY.ID = DEPARTMENT.EMP_ID

   UNION ALL

     SELECT EMP_ID, NAME, DEPT FROM COMPANY LEFT OUTER JOIN DEPARTMENT

        ON COMPANY.ID = DEPARTMENT.EMP_ID;

這將產生以下結果:

EMP_ID      NAME                  DEPT

———-  ——————–  ———-

1           Paul                  IT Billing

2           Allen                 Engineerin

3           Teddy                 Engineerin

4           Mark                  Finance

5           David                 Engineerin

6           Kim                   Finance

7           James                 Finance

1           Paul                  IT Billing

2           Allen                 Engineerin

3           Teddy                 Engineerin

4           Mark                  Finance

5           David                 Engineerin

6           Kim                   Finance

7           James                 Finance

 

 

 

 



 


發表迴響

你的電子郵件位址並不會被公開。 必要欄位標記為 *