⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 union.sql

📁 derby database source code.good for you.
💻 SQL
字号:
---- this test shows union functionality---- create the tablescreate table t1 (i int, s smallint, d double precision, r real, c10 char(10),				c30 char(30), vc10 varchar(10), vc30 varchar(30));create table t2 (i int, s smallint, d double precision, r real, c10 char(10),				c30 char(30), vc10 varchar(10), vc30 varchar(30));create table dups (i int, s smallint, d double precision, r real, c10 char(10),				c30 char(30), vc10 varchar(10), vc30 varchar(30));-- populate the tablesinsert into t1 values (null, null, null, null, null, null, null, null);insert into t1 values (1, 1, 1e1, 1e1, '11111', '11111     11', '11111',	'11111      11');insert into t1 values (2, 2, 2e1, 2e1, '22222', '22222     22', '22222',	'22222      22');insert into t2 values (null, null, null, null, null, null, null, null);insert into t2 values (3, 3, 3e1, 3e1, '33333', '33333     33', '33333',	'33333      33');insert into t2 values (4, 4, 4e1, 4e1, '44444', '44444     44', '44444',	'44444      44');insert into dups select * from t1 union all select * from t2;-- simple casesvalues (1, 2, 3, 4) union values (5, 6, 7, 8);values (1, 2, 3, 4) union values (1, 2, 3, 4);values (1, 2, 3, 4) union distinct values (5, 6, 7, 8);values (1, 2, 3, 4) union distinct values (1, 2, 3, 4);values (1, 2, 3, 4) union values (5, 6, 7, 8) union values (9, 10, 11, 12);values (1, 2, 3, 4) union values (1, 2, 3, 4) union values (1, 2, 3, 4);select * from t1 union select * from t2;select * from t1 union select * from t1;select * from t1 union select * from t2 union select * from dups;select * from t1 union select i, s, d, r, c10, c30, vc10, vc30 from t2;select * from t1 union select i, s, d, r, c10, c30, vc10, vc30 from t2		union select * from dups;-- derived tablesselect * from (values (1, 2, 3, 4) union values (5, 6, 7, 8)) a;select * from (values (1, 2, 3, 4) union values (5, 6, 7, 8) union			   values (1, 2, 3, 4)) a;-- mix unions and union allsselect i from t1 union select i from t2 union all select i from dups;(select i from t1 union select i from t2) union all select i from dups;select i from t1 union (select i from t2 union all select i from dups);select i from t1 union all select i from t2 union select i from dups;(select i from t1 union all select i from t2) union select i from dups;select i from t1 union all (select i from t2 union select i from dups);-- joinsselect a.i, b.i from t1 a, t2 b union select b.i, a.i from t1 a, t2 b;values (9, 10) union 	select a.i, b.i from t1 a, t2 b union select b.i, a.i from t1 a, t2 b;select a.i, b.i from t1 a, t2 b union 	select b.i, a.i from t1 a, t2 b union values (9, 10);-- non-correlated subqueries-- positive testsselect i from t1 where i = (values 1 union values 1);select i from t1 where i = (values 1 union values 1 union values 1);-- expression subqueryselect i from t1 where i = (select 1 from t2 union values 1);-- in subqueryselect i from t1 where i in (select i from t2 union values 1 union values 2);select i from t1 where i in 		(select a from (select i from t2 union values 1 union values 2) a (a));-- not in subqueryselect i from t1 where i not in (select i from t2 union values 1 union values 2);select i from t1 where i not in (select i from t2 where i is not null union 								 values 1 union values 22);select i from t1 where i not in 		(select a from (select i from t2 where i is not null union 						values 111 union values 2) a (a));-- correlated union subqueryselect i from t1 a where i in (select i from t2 where 1 = 0 union 							   select a.i from t2 where a.i < i);select i from t1 a where i in (select a.i from t2 where a.i < i union 							   select i from t2 where 1 < 0);-- exists subqueryselect i from t1 where exists (select * from t2 union select * from t2);select i from t1 where exists (select 1 from t2 union select 2 from t2);select i from t1 where exists (select 1 from t2 where 1 = 0 union 							   select * from t2 where t1.i < i);select i from t1 where exists (select i from t2 where t1.i < i union 							    select * from t2 where 1 = 0 union 							   select * from t2 where t1.i < i union 							    select i from t2 where 1 = 0);-- order by testsselect i from t1 union select i from dups order by i desc;select i, s from t1 union select s as i, 1 as s from dups order by s desc, i;-- insert testscreate table insert_test (i int, s smallint, d double precision, r real,	c10 char(10), c30 char(30), vc10 varchar(10), vc30 varchar(30));-- simple testsinsert into insert_test select * from t1 union select * from dups;select * from insert_test;delete from insert_test;insert into insert_test (s, i) values (2, 1) union values (4, 3);select * from insert_test;delete from insert_test;-- test type dominance/length/nullabilityinsert into insert_test (vc30) select vc10 from t1 union select c30 from t2;select * from insert_test;delete from insert_test;insert into insert_test (c30)	select vc10 from t1	union	select c30 from t2	union	select c10 from t1;select * from insert_test;delete from insert_test;-- test NormalizeResultSet generationselect i, d from t1 union select d, i from t2;select vc10, c30 from t1 union select c30, vc10 from t2;create table insert_test2 (s smallint not null, vc30 varchar(30) not null);-- the following should fail due to null constraintinsert into insert_test2 select s, c10 from t1 union select s, c30 from t2;select * from insert_test2;-- negative tests-- ? in select list of unionselect ? from insert_test union select vc30 from insert_test;select vc30 from insert_test union select ? from insert_test;-- DB2 requires matching target and result column for insertinsert into insert_test values (1, 2) union values (3, 4);-- try some unions of different types.  -- types should be ok if comparable.values (1) union values (1.1);values (1) union values (1.1e1);values (1.1) union values (1);values (1.1e1) union values (1);-- negative casesvalues (x'aa') union values (1);-- drop the tablesdrop table t1;drop table t2;drop table dups;drop table insert_test;drop table insert_test2;---- this test shows the current supported union all functionality---- RESOLVE - whats not tested--	type compatability--  nullability of result--  type dominance--  correlated subqueries--  table constructors-- create the tablescreate table t1 (i int, s smallint, d double precision, r real, c10 char(10),				 c30 char(30), vc10 varchar(10), vc30 varchar(30));create table t2 (i int, s smallint, d double precision, r real, c10 char(10),				 c30 char(30), vc10 varchar(10), vc30 varchar(30));-- populate the tablesinsert into t1 values (null, null, null, null, null, null, null, null);insert into t1 values (1, 1, 1e1, 1e1, '11111', '11111     11', '11111',	'11111      11');insert into t1 values (2, 2, 2e1, 2e1, '22222', '22222     22', '22222',	'22222      22');insert into t2 values (null, null, null, null, null, null, null, null);insert into t2 values (3, 3, 3e1, 3e1, '33333', '33333     33', '33333',	'33333      33');insert into t2 values (4, 4, 4e1, 4e1, '44444', '44444     44', '44444',	'44444      44');-- negative tests-- non matching number of columnsselect * from t1 union all select * from t1, t2;select * from t1 union all values (1, 2, 3, 4);values (1, 2, 3, 4) union all select * from t1;-- simple casesvalues (1, 2, 3, 4) union all values (5, 6, 7, 8);values (1, 2, 3, 4) union all values (5, 6, 7, 8) union all values (9, 10, 11, 12);select * from t1 union all select * from t2;select * from t1 union all select i, s, d, r, c10, c30, vc10, vc30 from t2;-- derived tablesselect * from (values (1, 2, 3, 4) union all values (5, 6, 7, 8)) a;select * from (values (1, 2, 3, 4) union all values (5, 6, 7, 8)) a (a, b, c, d);select b, d from (values (1, 2, 3, 4) union all values (5, 6, 7, 8)) a (a, b, c, d);select * from (select i, s, c10, vc10 from t1 union all select i, s, c10, vc10 from t2) a;select * from (select i, s, c10, vc10 from t1 union all 			   select i, s, c10, vc10 from t2) a (j, k, l, m), 			   (select i, s, c10, vc10 from t1 union all 			   select i, s, c10, vc10 from t2) b (j, k, l, m)where a.j = b.j;-- joinsselect a.i, b.i from t1 a, t2 b union all select b.i, a.i from t1 a, t2 b;values (9, 10) union all 	select a.i, b.i from t1 a, t2 b union all select b.i, a.i from t1 a, t2 b;select a.i, b.i from t1 a, t2 b union all 	select b.i, a.i from t1 a, t2 b union all values (9, 10);-- incompatible typesselect date('9999-11-11') from t1 union all select time('11:11:11') from t2;-- non-correlated subqueries-- negative tests-- select * in subqueryselect i from t1 where i = (select * from t2 union all select 1 from t1);select i from t1 where i = (select 1 from t2 union all select * from t1);-- too many columnsselect i from t1 where i = (values (1, 2, 3) union all values (1, 2, 3));select i from t1 where i = (select i, s from t2 union all select i, s from t1);-- cardinality violationselect i from t1 where i = (values 1 union all values 1);-- both sides of union have same type, which is incompatible with LHSselect i from t1 where i in (select date('1999-02-04') from t2 union all select date('1999-03-08') from t2);-- positive tests-- expression subqueryselect i from t1 where i = (select i from t2 where 1 = 0 union all values 1);-- in subqueryselect i from t1 where i in (select i from t2 union all values 1 union all values 2);select i from t1 where i in 		(select a from (select i from t2 union all values 1 union all values 2) a (a));-- not in subqueryselect i from t1 where i not in (select i from t2 union all values 1 union all values 2);select i from t1 where i not in (select i from t2 where i is not null union all 								 values 1 union all values 22);select i from t1 where i not in 		(select a from (select i from t2 where i is not null union all 						values 111 union all values 2) a (a));-- correlated union subqueryselect i from t1 a where i in (select i from t2 where 1 = 0 union all							   select a.i from t2 where a.i < i);select i from t1 a where i in (select a.i from t2 where a.i < i union all							   select i from t2 where 1 < 0);-- exists subqueryselect i from t1 where exists (select * from t2 union all select * from t2);select i from t1 where exists (select 1 from t2 union all select 2 from t2);select i from t1 where exists (select 1 from t2 where 1 = 0 union all							   select * from t2 where t1.i < i);select i from t1 where exists (select i from t2 where t1.i < i union all							    select * from t2 where 1 = 0 union all							   select * from t2 where t1.i < i union all							    select i from t2 where 1 = 0);-- insert testscreate table insert_test (i int, s smallint, d double precision, r real, c10 char(10),				 c30 char(30), vc10 varchar(10), vc30 varchar(30));-- simple testsinsert into insert_test select * from t1 union all select * from t2;select * from insert_test;delete from insert_test;insert into insert_test (s, i) values (2, 1) union all values (4, 3);select * from insert_test;delete from insert_test;-- type conversions between union all and target tableinsert into insert_test select s, i, r, d, vc10, vc30, c10, c30 from t1 union all						select s, i, r, d, vc10, vc30, c10, vc30 from t2;select * from insert_test;delete from insert_test;-- test type dominance/length/nullabilityselect vc10 from t1 union all select c30 from t2;insert into insert_test (vc30) select vc10 from t1 union all select c30 from t2;select * from insert_test;delete from insert_test;insert into insert_test (c30)	select vc10 from t1	union all	select c30 from t2	union all	select c10 from t1;select * from insert_test;delete from insert_test;-- test NormalizeResultSet generationselect i, d from t1 union all select d, i from t2;select vc10, c30 from t1 union all select c30,  vc10 from t2;create table insert_test2 (s smallint not null, vc30 varchar(30) not null);-- the following should fail due to null constraintinsert into insert_test2 select s, c10 from t1 union all select s, c30 from t2;select * from insert_test2;-- negative tests-- ? in select list of unionselect ? from insert_test union all select vc30 from insert_test;select vc30 from insert_test union all select ? from insert_test;-- DB2 requires matching target and result columnsinsert into insert_test values (1, 2) union all values (3, 4);-- Beetle 4454 - test multiple union alls in a subqueryselect vc10 from (select vc10 from t1 union allselect vc10 from t1 union allselect vc10 from t1 union allselect vc10 from t1 union allselect vc10 from t1 union allselect vc10 from t1 union allselect vc10 from t1) t;-- force union all on right sideselect vc10 from (select vc10 from t1 union all (select vc10 from t1 union allselect vc10 from t1)) t;-- drop the tablesdrop table t1;drop table t2;drop table insert_test;drop table insert_test2;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -