SQLite Unions 子句

sqlite unions 子句

sqlite的 union 子句/運算符用于合并兩個或多個 select 語句的結(jié)果,不返回任何重復的行。

為了使用 union,每個 select 被選擇的列數(shù)必須是相同的,相同數(shù)目的列表達式,相同的數(shù)據(jù)類型,并確保它們有相同的順序,但它們不必具有相同的長度。

 

1. 語法

union 的基本語法如下:

select column1 [, column2 ]
from table1 [, table2 ]
[where condition]

union

select column1 [, column2 ]
from table1 [, table2 ]
[where condition]

這里給定的條件根據(jù)需要可以是任何表達式。

假設(shè)有下面兩個表,(1)company 表如下所示:

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          rich-mond   65000.0
5           david                 27          texas       85000.0
6           kim                   22          south-hall  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

現(xiàn)在,讓我們使用 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;

這將產(chǎn)生以下結(jié)果:

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

 

2. union all 子句

union all 運算符用于結(jié)合兩個 select 語句的結(jié)果,包括重復行。

適用于 union 的規(guī)則同樣適用于 union all 運算符。

 

語法

union all 的基本語法如下:

select column1 [, column2 ]
from table1 [, table2 ]
[where condition]

union all

select column1 [, column2 ]
from table1 [, table2 ]
[where condition]

這里給定的條件根據(jù)需要可以是任何表達式。

現(xiàn)在,讓我們使用 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;

這將產(chǎn)生以下結(jié)果:

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

下一節(jié):sqlite null 值

sqlite教程

相關(guān)文章
亚洲国产精品第一区二区,久久免费视频77,99V久久综合狠狠综合久久,国产免费久久九九免费视频