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