Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
Postgres FD Implementation
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Abuhujair Javed
Postgres FD Implementation
Commits
67ac3808
Commit
67ac3808
authored
Jan 06, 2000
by
Thomas G. Lockhart
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update for new psql formatting.
parent
6e0cc2ac
Changes
11
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
1243 additions
and
1046 deletions
+1243
-1046
src/test/regress/expected/case.out
src/test/regress/expected/case.out
+181
-157
src/test/regress/expected/errors.out
src/test/regress/expected/errors.out
+1
-3
src/test/regress/expected/random.out
src/test/regress/expected/random.out
+24
-12
src/test/regress/expected/select.out
src/test/regress/expected/select.out
+339
-275
src/test/regress/expected/select_distinct.out
src/test/regress/expected/select_distinct.out
+114
-91
src/test/regress/expected/select_distinct_on.out
src/test/regress/expected/select_distinct_on.out
+14
-11
src/test/regress/expected/select_having.out
src/test/regress/expected/select_having.out
+32
-28
src/test/regress/expected/select_implicit.out
src/test/regress/expected/select_implicit.out
+248
-199
src/test/regress/expected/select_into.out
src/test/regress/expected/select_into.out
+7
-4
src/test/regress/expected/subselect.out
src/test/regress/expected/subselect.out
+106
-97
src/test/regress/expected/union.out
src/test/regress/expected/union.out
+177
-169
No files found.
src/test/regress/expected/case.out
View file @
67ac3808
QUERY: CREATE TABLE CASE_TBL (
--
-- CASE
-- Test the case statement
--
CREATE TABLE CASE_TBL (
i integer,
f double precision
);
QUERY:
CREATE TABLE CASE2_TBL (
CREATE TABLE CASE2_TBL (
i integer,
j integer
);
QUERY: INSERT INTO CASE_TBL VALUES (1, 10.1);
QUERY: INSERT INTO CASE_TBL VALUES (2, 20.2);
QUERY: INSERT INTO CASE_TBL VALUES (3, -30.3);
QUERY: INSERT INTO CASE_TBL VALUES (4, NULL);
QUERY: INSERT INTO CASE2_TBL VALUES (1, -1);
QUERY: INSERT INTO CASE2_TBL VALUES (2, -2);
QUERY: INSERT INTO CASE2_TBL VALUES (3, -3);
QUERY: INSERT INTO CASE2_TBL VALUES (2, -4);
QUERY: INSERT INTO CASE2_TBL VALUES (1, NULL);
QUERY: INSERT INTO CASE2_TBL VALUES (NULL, -6);
QUERY: SELECT '3' AS "One",
INSERT INTO CASE_TBL VALUES (1, 10.1);
INSERT INTO CASE_TBL VALUES (2, 20.2);
INSERT INTO CASE_TBL VALUES (3, -30.3);
INSERT INTO CASE_TBL VALUES (4, NULL);
INSERT INTO CASE2_TBL VALUES (1, -1);
INSERT INTO CASE2_TBL VALUES (2, -2);
INSERT INTO CASE2_TBL VALUES (3, -3);
INSERT INTO CASE2_TBL VALUES (2, -4);
INSERT INTO CASE2_TBL VALUES (1, NULL);
INSERT INTO CASE2_TBL VALUES (NULL, -6);
--
-- Simplest examples without tables
--
SELECT '3' AS "One",
CASE
WHEN 1 < 2 THEN 3
END AS "Simple WHEN";
One|Simple WHEN
---
+
-----------
3|
3
One | Simple WHEN
---
--+--
-----------
3 |
3
(1 row)
QUERY:
SELECT '<NULL>' AS "One",
SELECT '<NULL>' AS "One",
CASE
WHEN 1 > 2 THEN 3
END AS "Simple default";
One |Simple default
------
+
--------------
<NULL>|
One | Simple default
------
--+--
--------------
<NULL> |
(1 row)
QUERY:
SELECT '3' AS "One",
SELECT '3' AS "One",
CASE
WHEN 1 < 2 THEN 3
ELSE 4
END AS "Simple ELSE";
One|Simple ELSE
---
+
-----------
3|
3
One | Simple ELSE
---
--+--
-----------
3 |
3
(1 row)
QUERY:
SELECT '4' AS "One",
SELECT '4' AS "One",
CASE
WHEN 1 > 2 THEN 3
ELSE 4
END AS "ELSE default";
One|ELSE default
---
+
------------
4|
4
One | ELSE default
---
--+--
------------
4 |
4
(1 row)
QUERY:
SELECT '6' AS "One",
SELECT '6' AS "One",
CASE
WHEN 1 > 2 THEN 3
WHEN 4 < 5 THEN 6
ELSE 7
END AS "Two WHEN with default";
One|Two WHEN with default
---
+
---------------------
6|
6
One | Two WHEN with default
---
--+--
---------------------
6 |
6
(1 row)
QUERY: SELECT '' AS "Five",
--
-- Examples of targets involving tables
--
SELECT '' AS "Five",
CASE
WHEN i >= 3 THEN i
END AS ">= 3 or Null"
FROM CASE_TBL;
Five|>= 3 or Null
----
+
------------
|
|
|
3
|
4
Five | >= 3 or Null
----
--+--
------------
|
|
|
3
|
4
(4 rows)
QUERY:
SELECT '' AS "Five",
SELECT '' AS "Five",
CASE WHEN i >= 3 THEN (i + i)
ELSE i
END AS "Simplest Math"
FROM CASE_TBL;
Five|Simplest Math
----
+
-------------
|
1
|
2
|
6
|
8
Five | Simplest Math
----
--+--
-------------
|
1
|
2
|
6
|
8
(4 rows)
QUERY:
SELECT '' AS "Five", i AS "Value",
SELECT '' AS "Five", i AS "Value",
CASE WHEN (i < 0) THEN 'small'
WHEN (i = 0) THEN 'zero'
WHEN (i = 1) THEN 'one'
...
...
@@ -99,15 +109,15 @@ QUERY: SELECT '' AS "Five", i AS "Value",
ELSE 'big'
END AS "Category"
FROM CASE_TBL;
Five|Value|Category
----
+-----+
--------
| 1|one
| 2|two
| 3|big
| 4|big
Five | Value | Category
----
--+-------+--
--------
| 1 | one
| 2 | two
| 3 | big
| 4 | big
(4 rows)
QUERY:
SELECT '' AS "Five",
SELECT '' AS "Five",
CASE WHEN ((i < 0) or (i < 0)) THEN 'small'
WHEN ((i = 0) or (i = 0)) THEN 'zero'
WHEN ((i = 1) or (i = 1)) THEN 'one'
...
...
@@ -115,141 +125,155 @@ QUERY: SELECT '' AS "Five",
ELSE 'big'
END AS "Category"
FROM CASE_TBL;
Five|Category
----
+
--------
|one
|two
|big
|big
Five | Category
----
--+--
--------
| one
| two
| big
| big
(4 rows)
QUERY: SELECT * FROM CASE_TBL WHERE COALESCE(f,i) = 4;
i|f
-+-
4|
--
-- Examples of qualifications involving tables
--
--
-- NULLIF() and COALESCE()
-- Shorthand forms for typical CASE constructs
-- defined in the SQL92 standard.
--
SELECT * FROM CASE_TBL WHERE COALESCE(f,i) = 4;
i | f
---+---
4 |
(1 row)
QUERY:
SELECT * FROM CASE_TBL WHERE NULLIF(f,i) = 2;
i|f
-
+
-
SELECT * FROM CASE_TBL WHERE NULLIF(f,i) = 2;
i | f
-
--+--
-
(0 rows)
QUERY:
SELECT COALESCE(a.f, b.i, b.j)
SELECT COALESCE(a.f, b.i, b.j)
FROM CASE_TBL a, CASE2_TBL b;
case
-----
10.1
20.2
-30.3
1
10.1
20.2
-30.3
2
10.1
20.2
-30.3
3
10.1
20.2
-30.3
2
10.1
20.2
-30.3
1
10.1
20.2
-30.3
-6
case
-----
--
10.1
20.2
-30.3
1
10.1
20.2
-30.3
2
10.1
20.2
-30.3
3
10.1
20.2
-30.3
2
10.1
20.2
-30.3
1
10.1
20.2
-30.3
-6
(24 rows)
QUERY:
SELECT *
SELECT *
FROM CASE_TBL a, CASE2_TBL b
WHERE COALESCE(a.f, b.i, b.j) = 2;
i|f|i| j
-
+-+-+
--
4| |2|
-2
4| |2|
-4
i | f | i | j
-
--+---+---+--
--
4 | | 2 |
-2
4 | | 2 |
-4
(2 rows)
QUERY:
SELECT '' AS Five, NULLIF(a.i,b.i) AS "NULLIF(a.i,b.i)",
SELECT '' AS Five, NULLIF(a.i,b.i) AS "NULLIF(a.i,b.i)",
NULLIF(b.i, 4) AS "NULLIF(b.i,4)"
FROM CASE_TBL a, CASE2_TBL b;
five|NULLIF(a.i,b.i)|NULLIF(b.i,4)
----
+---------------+
-------------
| |
1
| 2|
1
| 3|
1
| 4|
1
| 1|
2
| |
2
| 3|
2
| 4|
2
| 1|
3
| 2|
3
| |
3
| 4|
3
| 1|
2
| |
2
| 3|
2
| 4|
2
| |
1
| 2|
1
| 3|
1
| 4|
1
| 1|
| 2|
| 3|
| 4|
five | NULLIF(a.i,b.i) | NULLIF(b.i,4)
----
--+-----------------+--
-------------
| |
1
| 2 |
1
| 3 |
1
| 4 |
1
| 1 |
2
| |
2
| 3 |
2
| 4 |
2
| 1 |
3
| 2 |
3
| |
3
| 4 |
3
| 1 |
2
| |
2
| 3 |
2
| 4 |
2
| |
1
| 2 |
1
| 3 |
1
| 4 |
1
| 1 |
| 2 |
| 3 |
| 4 |
(24 rows)
QUERY:
SELECT '' AS "Two", *
SELECT '' AS "Two", *
FROM CASE_TBL a, CASE2_TBL b
WHERE COALESCE(f,b.i) = 2;
Two|i|f|i| j
---
+-+-+-+
--
|4| |2|
-2
|4| |2|
-4
Two | i | f | i | j
---
--+---+---+---+--
--
| 4 | | 2 |
-2
| 4 | | 2 |
-4
(2 rows)
QUERY: UPDATE CASE_TBL
--
-- Examples of updates involving tables
--
UPDATE CASE_TBL
SET i = CASE WHEN i >= 3 THEN (- i)
ELSE (2 * i) END;
QUERY:
SELECT * FROM CASE_TBL;
i
| f
--
+
-----
2|
10.1
4|
20.2
-3|
-30.3
-4|
SELECT * FROM CASE_TBL;
i
| f
--
--+--
-----
2 |
10.1
4 |
20.2
-3 |
-30.3
-4 |
(4 rows)
QUERY:
UPDATE CASE_TBL
UPDATE CASE_TBL
SET i = CASE WHEN i >= 2 THEN (2 * i)
ELSE (3 * i) END;
QUERY:
SELECT * FROM CASE_TBL;
i
| f
---
+
-----
4|
10.1
8|
20.2
-9|
-30.3
-12|
SELECT * FROM CASE_TBL;
i
| f
---
--+--
-----
4 |
10.1
8 |
20.2
-9 |
-30.3
-12 |
(4 rows)
QUERY:
UPDATE CASE_TBL
UPDATE CASE_TBL
SET i = CASE WHEN b.i >= 2 THEN (2 * j)
ELSE (3 * j) END
FROM CASE2_TBL b
WHERE j = -CASE_TBL.i;
QUERY:
SELECT * FROM CASE_TBL;
i
| f
---
+
-----
8|
20.2
-9|
-30.3
-12|
-8|
10.1
SELECT * FROM CASE_TBL;
i
| f
---
--+--
-----
8 |
20.2
-9 |
-30.3
-12 |
-8 |
10.1
(4 rows)
QUERY: DROP TABLE CASE_TBL;
QUERY: DROP TABLE CASE2_TBL;
--
-- Clean up
--
DROP TABLE CASE_TBL;
DROP TABLE CASE2_TBL;
src/test/regress/expected/errors.out
View file @
67ac3808
--
--
errors.source
--
ERRORS
--
-- $Header: /cvsroot/pgsql/src/test/regress/expected/errors.out,v 1.15 2000/01/05 17:31:08 thomas Exp $
-- bad in postquel, but ok in postsql
select 1
--
...
...
src/test/regress/expected/random.out
View file @
67ac3808
QUERY: SELECT count(*) FROM onek;
count
-----
1000
--
-- RANDOM
-- Test the random function
--
-- count the number of tuples originally
SELECT count(*) FROM onek;
count
-------
1000
(1 row)
QUERY: SELECT count(*) AS random INTO RANDOM_TBL
-- select roughly 1/10 of the tuples
-- Assume that the "onek" table has 1000 tuples
-- and try to bracket the correct number so we
-- have a regression test which can pass/fail
-- - thomas 1998-08-17
SELECT count(*) AS random INTO RANDOM_TBL
FROM onek WHERE oidrand(onek.oid, 10);
QUERY: INSERT INTO RANDOM_TBL (random)
-- select again, the count should be different
INSERT INTO RANDOM_TBL (random)
SELECT count(*)
FROM onek WHERE oidrand(onek.oid, 10);
QUERY: SELECT random, count(random) FROM RANDOM_TBL
-- now test the results for randomness in the correct range
SELECT random, count(random) FROM RANDOM_TBL
GROUP BY random HAVING count(random) > 1;
random|count
------
+
-----
random | count
------
--+--
-----
(0 rows)
QUERY:
SELECT random FROM RANDOM_TBL
SELECT random FROM RANDOM_TBL
WHERE random NOT BETWEEN 80 AND 120;
random
------
random
------
--
(0 rows)
src/test/regress/expected/select.out
View file @
67ac3808
This diff is collapsed.
Click to expand it.
src/test/regress/expected/select_distinct.out
View file @
67ac3808
QUERY: SELECT DISTINCT two FROM tmp;
two
---
0
1
--
-- SELECT_DISTINCT
--
--
-- awk '{print $3;}' onek.data | sort -n | uniq
--
SELECT DISTINCT two FROM tmp;
two
-----
0
1
(2 rows)
QUERY: SELECT DISTINCT ten FROM tmp;
ten
---
0
1
2
3
4
5
6
7
8
9
--
-- awk '{print $5;}' onek.data | sort -n | uniq
--
SELECT DISTINCT ten FROM tmp;
ten
-----
0
1
2
3
4
5
6
7
8
9
(10 rows)
QUERY: SELECT DISTINCT string4 FROM tmp;
string4
-------
AAAAxx
HHHHxx
OOOOxx
VVVVxx
--
-- awk '{print $16;}' onek.data | sort -d | uniq
--
SELECT DISTINCT string4 FROM tmp;
string4
---------
AAAAxx
HHHHxx
OOOOxx
VVVVxx
(4 rows)
QUERY: SELECT DISTINCT two, string4, ten
--
-- awk '{print $3,$16,$5;}' onek.data | sort -d | uniq |
-- sort +0n -1 +1d -2 +2n -3
--
SELECT DISTINCT two, string4, ten
FROM tmp
ORDER BY two using <, string4 using <, ten using <;
two|string4|ten
---
+-------+
---
0|AAAAxx |
0
0|AAAAxx |
2
0|AAAAxx |
4
0|AAAAxx |
6
0|AAAAxx |
8
0|HHHHxx |
0
0|HHHHxx |
2
0|HHHHxx |
4
0|HHHHxx |
6
0|HHHHxx |
8
0|OOOOxx |
0
0|OOOOxx |
2
0|OOOOxx |
4
0|OOOOxx |
6
0|OOOOxx |
8
0|VVVVxx |
0
0|VVVVxx |
2
0|VVVVxx |
4
0|VVVVxx |
6
0|VVVVxx |
8
1|AAAAxx |
1
1|AAAAxx |
3
1|AAAAxx |
5
1|AAAAxx |
7
1|AAAAxx |
9
1|HHHHxx |
1
1|HHHHxx |
3
1|HHHHxx |
5
1|HHHHxx |
7
1|HHHHxx |
9
1|OOOOxx |
1
1|OOOOxx |
3
1|OOOOxx |
5
1|OOOOxx |
7
1|OOOOxx |
9
1|VVVVxx |
1
1|VVVVxx |
3
1|VVVVxx |
5
1|VVVVxx |
7
1|VVVVxx |
9
two | string4 | ten
---
--+---------+--
---
0 | AAAAxx |
0
0 | AAAAxx |
2
0 | AAAAxx |
4
0 | AAAAxx |
6
0 | AAAAxx |
8
0 | HHHHxx |
0
0 | HHHHxx |
2
0 | HHHHxx |
4
0 | HHHHxx |
6
0 | HHHHxx |
8
0 | OOOOxx |
0
0 | OOOOxx |
2
0 | OOOOxx |
4
0 | OOOOxx |
6
0 | OOOOxx |
8
0 | VVVVxx |
0
0 | VVVVxx |
2
0 | VVVVxx |
4
0 | VVVVxx |
6
0 | VVVVxx |
8
1 | AAAAxx |
1
1 | AAAAxx |
3
1 | AAAAxx |
5
1 | AAAAxx |
7
1 | AAAAxx |
9
1 | HHHHxx |
1
1 | HHHHxx |
3
1 | HHHHxx |
5
1 | HHHHxx |
7
1 | HHHHxx |
9
1 | OOOOxx |
1
1 | OOOOxx |
3
1 | OOOOxx |
5
1 | OOOOxx |
7
1 | OOOOxx |
9
1 | VVVVxx |
1
1 | VVVVxx |
3
1 | VVVVxx |
5
1 | VVVVxx |
7
1 | VVVVxx |
9
(40 rows)
QUERY: SELECT DISTINCT p.age FROM person* p ORDER BY age using >;
age
---
98
88
78
68
60
58
50
48
40
38
34
30
28
25
24
23
20
19
18
8
--
-- awk '{print $2;}' person.data |
-- awk '{if(NF!=1){print $2;}else{print;}}' - emp.data |
-- awk '{if(NF!=1){print $2;}else{print;}}' - student.data |
-- awk 'BEGIN{FS=" ";}{if(NF!=1){print $5;}else{print;}}' - stud_emp.data |
-- sort -n -r | uniq
--
SELECT DISTINCT p.age FROM person* p ORDER BY age using >;
age
-----
98
88
78
68
60
58
50
48
40
38
34
30
28
25
24
23
20
19
18
8
(20 rows)
src/test/regress/expected/select_distinct_on.out
View file @
67ac3808
QUERY: SELECT DISTINCT ON string4 two, string4, ten
--
-- SELECT_DISTINCT_ON
--
SELECT DISTINCT ON string4 two, string4, ten
FROM tmp
ORDER BY two using <, string4 using <, ten using <;
two|string4|ten
---
+-------+
---
0|AAAAxx |
0
0|HHHHxx |
0
0|OOOOxx |
0
0|VVVVxx |
0
1|AAAAxx |
1
1|HHHHxx |
1
1|OOOOxx |
1
1|VVVVxx |
1
two | string4 | ten
---
--+---------+--
---
0 | AAAAxx |
0
0 | HHHHxx |
0
0 | OOOOxx |
0
0 | VVVVxx |
0
1 | AAAAxx |
1
1 | HHHHxx |
1
1 | OOOOxx |
1
1 | VVVVxx |
1
(8 rows)
src/test/regress/expected/select_having.out
View file @
67ac3808
QUERY: CREATE TABLE test_having (a int, b int, c char(8), d char);
QUERY: INSERT INTO test_having VALUES (0, 1, 'XXXX', 'A');
QUERY: INSERT INTO test_having VALUES (1, 2, 'AAAA', 'b');
QUERY: INSERT INTO test_having VALUES (2, 2, 'AAAA', 'c');
QUERY: INSERT INTO test_having VALUES (3, 3, 'BBBB', 'D');
QUERY: INSERT INTO test_having VALUES (4, 3, 'BBBB', 'e');
QUERY: INSERT INTO test_having VALUES (5, 3, 'bbbb', 'F');
QUERY: INSERT INTO test_having VALUES (6, 4, 'cccc', 'g');
QUERY: INSERT INTO test_having VALUES (7, 4, 'cccc', 'h');
QUERY: INSERT INTO test_having VALUES (8, 4, 'CCCC', 'I');
QUERY: INSERT INTO test_having VALUES (9, 4, 'CCCC', 'j');
QUERY: SELECT b, c FROM test_having
--
-- SELECT_HAVING
--
-- load test data
CREATE TABLE test_having (a int, b int, c char(8), d char);
INSERT INTO test_having VALUES (0, 1, 'XXXX', 'A');
INSERT INTO test_having VALUES (1, 2, 'AAAA', 'b');
INSERT INTO test_having VALUES (2, 2, 'AAAA', 'c');
INSERT INTO test_having VALUES (3, 3, 'BBBB', 'D');
INSERT INTO test_having VALUES (4, 3, 'BBBB', 'e');
INSERT INTO test_having VALUES (5, 3, 'bbbb', 'F');
INSERT INTO test_having VALUES (6, 4, 'cccc', 'g');
INSERT INTO test_having VALUES (7, 4, 'cccc', 'h');
INSERT INTO test_having VALUES (8, 4, 'CCCC', 'I');
INSERT INTO test_having VALUES (9, 4, 'CCCC', 'j');
SELECT b, c FROM test_having
GROUP BY b, c HAVING count(*) = 1;
b|c
-
+
--------
1|
XXXX
3|
bbbb
b | c
-
--+--
--------
1 |
XXXX
3 |
bbbb
(2 rows)
QUERY:
SELECT lower(c), count(c) FROM test_having
SELECT lower(c), count(c) FROM test_having
GROUP BY lower(c) HAVING count(*) > 2 OR min(a) = max(a);
lower |count
--------
+
-----
bbbb |
3
cccc |
4
xxxx |
1
lower | count
--------
--+--
-----
bbbb |
3
cccc |
4
xxxx |
1
(3 rows)
QUERY:
SELECT c, max(a) FROM test_having
SELECT c, max(a) FROM test_having
GROUP BY c HAVING count(*) > 2 OR min(a) = max(a);
c |max
--------
+
---
XXXX |
0
bbbb |
5
c | max
--------
--+--
---
XXXX |
0
bbbb |
5
(2 rows)
QUERY:
DROP TABLE test_having;
DROP TABLE test_having;
src/test/regress/expected/select_implicit.out
View file @
67ac3808
This diff is collapsed.
Click to expand it.
src/test/regress/expected/select_into.out
View file @
67ac3808
QUERY: SELECT *
--
-- SELECT_INTO
--
SELECT *
INTO TABLE tmp1
FROM tmp
WHERE onek.unique1 < 2;
QUERY:
DROP TABLE tmp1;
QUERY:
SELECT *
DROP TABLE tmp1;
SELECT *
INTO TABLE tmp1
FROM tmp
WHERE onek2.unique1 < 2;
QUERY:
DROP TABLE tmp1;
DROP TABLE tmp1;
src/test/regress/expected/subselect.out
View file @
67ac3808
QUERY: SELECT 1 AS one WHERE 1 IN (SELECT 1);
one
---
1
--
-- SUBSELECT
--
SELECT 1 AS one WHERE 1 IN (SELECT 1);
one
-----
1
(1 row)
QUERY:
SELECT 1 AS zero WHERE 1 NOT IN (SELECT 1);
zero
----
SELECT 1 AS zero WHERE 1 NOT IN (SELECT 1);
zero
----
--
(0 rows)
QUERY:
SELECT 1 AS zero WHERE 1 IN (SELECT 2);
zero
----
SELECT 1 AS zero WHERE 1 IN (SELECT 2);
zero
----
--
(0 rows)
QUERY: CREATE TABLE SUBSELECT_TBL (
-- Set up some simple test tables
CREATE TABLE SUBSELECT_TBL (
f1 integer,
f2 integer,
f3 float
);
QUERY:
INSERT INTO SUBSELECT_TBL VALUES (1, 2, 3);
QUERY:
INSERT INTO SUBSELECT_TBL VALUES (2, 3, 4);
QUERY:
INSERT INTO SUBSELECT_TBL VALUES (3, 4, 5);
QUERY:
INSERT INTO SUBSELECT_TBL VALUES (1, 1, 1);
QUERY:
INSERT INTO SUBSELECT_TBL VALUES (2, 2, 2);
QUERY:
INSERT INTO SUBSELECT_TBL VALUES (3, 3, 3);
QUERY:
INSERT INTO SUBSELECT_TBL VALUES (6, 7, 8);
QUERY:
INSERT INTO SUBSELECT_TBL VALUES (8, 9, NULL);
QUERY:
SELECT '' AS eight, * FROM SUBSELECT_TBL;
eight|f1|f2|f3
-----
+--+--+
--
| 1| 2|
3
| 2| 3|
4
| 3| 4|
5
| 1| 1|
1
| 2| 2|
2
| 3| 3|
3
| 6| 7|
8
| 8| 9|
INSERT INTO SUBSELECT_TBL VALUES (1, 2, 3);
INSERT INTO SUBSELECT_TBL VALUES (2, 3, 4);
INSERT INTO SUBSELECT_TBL VALUES (3, 4, 5);
INSERT INTO SUBSELECT_TBL VALUES (1, 1, 1);
INSERT INTO SUBSELECT_TBL VALUES (2, 2, 2);
INSERT INTO SUBSELECT_TBL VALUES (3, 3, 3);
INSERT INTO SUBSELECT_TBL VALUES (6, 7, 8);
INSERT INTO SUBSELECT_TBL VALUES (8, 9, NULL);
SELECT '' AS eight, * FROM SUBSELECT_TBL;
eight | f1 | f2 | f3
-----
--+----+----+--
--
| 1 | 2 |
3
| 2 | 3 |
4
| 3 | 4 |
5
| 1 | 1 |
1
| 2 | 2 |
2
| 3 | 3 |
3
| 6 | 7 |
8
| 8 | 9 |
(8 rows)
QUERY: SELECT '' AS two, f1 AS "Constant Select" FROM SUBSELECT_TBL
-- Uncorrelated subselects
SELECT '' AS two, f1 AS "Constant Select" FROM SUBSELECT_TBL
WHERE f1 IN (SELECT 1);
two|Constant Select
---
+
---------------
|
1
|
1
two | Constant Select
---
--+--
---------------
|
1
|
1
(2 rows)
QUERY:
SELECT '' AS six, f1 AS "Uncorrelated Field" FROM SUBSELECT_TBL
SELECT '' AS six, f1 AS "Uncorrelated Field" FROM SUBSELECT_TBL
WHERE f1 IN (SELECT f2 FROM SUBSELECT_TBL);
six|Uncorrelated Field
---
+
------------------
|
1
|
2
|
3
|
1
|
2
|
3
six | Uncorrelated Field
---
--+--
------------------
|
1
|
2
|
3
|
1
|
2
|
3
(6 rows)
QUERY:
SELECT '' AS six, f1 AS "Uncorrelated Field" FROM SUBSELECT_TBL
SELECT '' AS six, f1 AS "Uncorrelated Field" FROM SUBSELECT_TBL
WHERE f1 IN (SELECT f2 FROM SUBSELECT_TBL WHERE
f2 IN (SELECT f1 FROM SUBSELECT_TBL));
six|Uncorrelated Field
---
+
------------------
|
1
|
2
|
3
|
1
|
2
|
3
six | Uncorrelated Field
---
--+--
------------------
|
1
|
2
|
3
|
1
|
2
|
3
(6 rows)
QUERY: SELECT '' AS six, f1 AS "Correlated Field", f3 AS "Second Field"
-- Correlated subselects
SELECT '' AS six, f1 AS "Correlated Field", f3 AS "Second Field"
FROM SUBSELECT_TBL
WHERE f1 IN (SELECT f2 FROM SUBSELECT_TBL WHERE f2 = f1);
six|Correlated Field|Second Field
---
+----------------+
------------
| 1|
3
| 2|
4
| 3|
5
| 1|
1
| 2|
2
| 3|
3
six | Correlated Field | Second Field
---
--+------------------+--
------------
| 1 |
3
| 2 |
4
| 3 |
5
| 1 |
1
| 2 |
2
| 3 |
3
(6 rows)
QUERY:
SELECT '' AS six, f1 AS "Correlated Field", f3 AS "Second Field"
SELECT '' AS six, f1 AS "Correlated Field", f3 AS "Second Field"
FROM SUBSELECT_TBL
WHERE f1 IN (SELECT f2 FROM SUBSELECT_TBL WHERE CAST(f2 AS float) = f3);
six|Correlated Field|Second Field
---
+----------------+
------------
| 1|
3
| 2|
4
| 3|
5
| 1|
1
| 2|
2
| 3|
3
six | Correlated Field | Second Field
---
--+------------------+--
------------
| 1 |
3
| 2 |
4
| 3 |
5
| 1 |
1
| 2 |
2
| 3 |
3
(6 rows)
QUERY:
SELECT '' AS six, f1 AS "Correlated Field", f3 AS "Second Field"
SELECT '' AS six, f1 AS "Correlated Field", f3 AS "Second Field"
FROM SUBSELECT_TBL
WHERE f1 IN (SELECT f2 FROM SUBSELECT_TBL WHERE f2 = CAST(f3 AS integer));
ERROR: dtoi4: unable to convert null
QUERY:
SELECT '' AS five, f1 AS "Correlated Field"
SELECT '' AS five, f1 AS "Correlated Field"
FROM SUBSELECT_TBL
WHERE (f1, f2) IN (SELECT f2, CAST(f3 AS int4) FROM SUBSELECT_TBL WHERE f3 IS NOT NULL);
five|Correlated Field
----
+
----------------
|
2
|
3
|
1
|
2
|
3
five | Correlated Field
----
--+--
----------------
|
2
|
3
|
1
|
2
|
3
(5 rows)
QUERY:
SELECT '' AS three, f1 AS "Correlated Field"
SELECT '' AS three, f1 AS "Correlated Field"
FROM SUBSELECT_TBL
WHERE (f1, f2) NOT IN (SELECT f2, CAST(f3 AS int4) FROM SUBSELECT_TBL WHERE f3 IS NOT NULL);
three|Correlated Field
-----
+
----------------
|
1
|
6
|
8
three | Correlated Field
-----
--+--
----------------
|
1
|
6
|
8
(3 rows)
QUERY: SELECT '' AS eight, ss.f1 AS "Correlated Field", ss.f3 AS "Second Field"
--
-- Use some existing tables in the regression test
--
SELECT '' AS eight, ss.f1 AS "Correlated Field", ss.f3 AS "Second Field"
FROM SUBSELECT_TBL ss
WHERE f1 NOT IN (SELECT f1 FROM INT4_TBL WHERE f1 != ss.f1);
eight|Correlated Field|Second Field
-----
+----------------+
------------
| 1|
3
| 2|
4
| 3|
5
| 1|
1
| 2|
2
| 3|
3
| 6|
8
| 8|
eight | Correlated Field | Second Field
-----
--+------------------+--
------------
| 1 |
3
| 2 |
4
| 3 |
5
| 1 |
1
| 2 |
2
| 3 |
3
| 6 |
8
| 8 |
(8 rows)
src/test/regress/expected/union.out
View file @
67ac3808
QUERY: SELECT 1 AS two UNION SELECT 2;
two
---
1
2
--
-- UNION
--
-- Simple UNION constructs
SELECT 1 AS two UNION SELECT 2;
two
-----
1
2
(2 rows)
QUERY:
SELECT 1 AS one UNION SELECT 1;
one
---
1
SELECT 1 AS one UNION SELECT 1;
one
---
--
1
(1 row)
QUERY:
SELECT 1 AS two UNION ALL SELECT 2;
two
---
1
2
SELECT 1 AS two UNION ALL SELECT 2;
two
---
--
1
2
(2 rows)
QUERY:
SELECT 1 AS two UNION ALL SELECT 1;
two
---
1
1
SELECT 1 AS two UNION ALL SELECT 1;
two
---
--
1
1
(2 rows)
QUERY:
SELECT 1 AS three UNION SELECT 2 UNION SELECT 3;
three
-----
1
2
3
SELECT 1 AS three UNION SELECT 2 UNION SELECT 3;
three
-----
--
1
2
3
(3 rows)
QUERY:
SELECT 1 AS two UNION SELECT 2 UNION SELECT 2;
two
---
1
2
SELECT 1 AS two UNION SELECT 2 UNION SELECT 2;
two
---
--
1
2
(2 rows)
QUERY:
SELECT 1 AS three UNION SELECT 2 UNION ALL SELECT 2;
three
-----
1
2
2
SELECT 1 AS three UNION SELECT 2 UNION ALL SELECT 2;
three
-----
--
1
2
2
(3 rows)
QUERY:
SELECT 1.1 AS two UNION SELECT 2.2;
two
---
1.1
2.2
SELECT 1.1 AS two UNION SELECT 2.2;
two
---
--
1.1
2.2
(2 rows)
QUERY: SELECT 1.1 AS two UNION SELECT 2;
two
---
1.1
2
-- Mixed types
SELECT 1.1 AS two UNION SELECT 2;
two
-----
1.1
2
(2 rows)
QUERY:
SELECT 1 AS two UNION SELECT 2.2;
two
---
1
2
SELECT 1 AS two UNION SELECT 2.2;
two
---
--
1
2
(2 rows)
QUERY:
SELECT 1 AS one UNION SELECT 1.1;
one
---
1
SELECT 1 AS one UNION SELECT 1.1;
one
---
--
1
(1 row)
QUERY:
SELECT 1.1 AS two UNION ALL SELECT 2;
two
---
1.1
2
SELECT 1.1 AS two UNION ALL SELECT 2;
two
---
--
1.1
2
(2 rows)
QUERY:
SELECT 1 AS two UNION ALL SELECT 1;
two
---
1
1
SELECT 1 AS two UNION ALL SELECT 1;
two
---
--
1
1
(2 rows)
QUERY:
SELECT 1 AS three UNION SELECT 2 UNION SELECT 3;
three
-----
1
2
3
SELECT 1 AS three UNION SELECT 2 UNION SELECT 3;
three
-----
--
1
2
3
(3 rows)
QUERY:
SELECT 1 AS two UNION SELECT 2 UNION SELECT 2;
two
---
1
2
SELECT 1 AS two UNION SELECT 2 UNION SELECT 2;
two
---
--
1
2
(2 rows)
QUERY:
SELECT 1 AS three UNION SELECT 2 UNION ALL SELECT 2;
three
-----
1
2
2
SELECT 1 AS three UNION SELECT 2 UNION ALL SELECT 2;
three
-----
--
1
2
2
(3 rows)
QUERY: SELECT f1 AS five FROM FLOAT8_TBL
--
-- Try testing from tables...
--
SELECT f1 AS five FROM FLOAT8_TBL
UNION
SELECT f1 FROM FLOAT8_TBL;
five
---------------------
-1.2345678901234e+200
-1004.3
-34.84
-1.2345678901234e-200
0
five
---------------------
--
-1.2345678901234e+200
-1004.3
-34.84
-1.2345678901234e-200
0
(5 rows)
QUERY:
SELECT f1 AS ten FROM FLOAT8_TBL
SELECT f1 AS ten FROM FLOAT8_TBL
UNION ALL
SELECT f1 FROM FLOAT8_TBL;
ten
---------------------
0
-34.84
-1004.3
-1.2345678901234e+200
-1.2345678901234e-200
0
-34.84
-1004.3
-1.2345678901234e+200
-1.2345678901234e-200
ten
---------------------
--
0
-34.84
-1004.3
-1.2345678901234e+200
-1.2345678901234e-200
0
-34.84
-1004.3
-1.2345678901234e+200
-1.2345678901234e-200
(10 rows)
QUERY:
SELECT f1 AS nine FROM FLOAT8_TBL
SELECT f1 AS nine FROM FLOAT8_TBL
UNION
SELECT f1 FROM INT4_TBL;
nine
---------------------
-1.2345678901234e+200
-2147483647
-123456
-1004.3
-34.84
-1.2345678901234e-200
0
123456
2147483647
nine
---------------------
--
-1.2345678901234e+200
-2147483647
-123456
-1004.3
-34.84
-1.2345678901234e-200
0
123456
2147483647
(9 rows)
QUERY:
SELECT f1 AS ten FROM FLOAT8_TBL
SELECT f1 AS ten FROM FLOAT8_TBL
UNION ALL
SELECT f1 FROM INT4_TBL;
ten
---------------------
0
-34.84
-1004.3
-1.2345678901234e+200
-1.2345678901234e-200
0
123456
-123456
2147483647
-2147483647
ten
---------------------
--
0
-34.84
-1004.3
-1.2345678901234e+200
-1.2345678901234e-200
0
123456
-123456
2147483647
-2147483647
(10 rows)
QUERY:
SELECT f1 AS five FROM FLOAT8_TBL
SELECT f1 AS five FROM FLOAT8_TBL
WHERE f1 BETWEEN -1e6 AND 1e6
UNION
SELECT f1 FROM INT4_TBL
WHERE f1 BETWEEN 0 AND 1000000;
five
---------------------
-1004.3
-34.84
-1.2345678901234e-200
0
123456
five
---------------------
--
-1004.3
-34.84
-1.2345678901234e-200
0
123456
(5 rows)
QUERY:
SELECT f1 AS five FROM VARCHAR_TBL
SELECT f1 AS five FROM VARCHAR_TBL
UNION
SELECT f1 FROM CHAR_TBL;
five
----
a
a
ab
ab
abcd
five
----
--
a
a
ab
ab
abcd
(5 rows)
QUERY:
SELECT f1 AS three FROM VARCHAR_TBL
SELECT f1 AS three FROM VARCHAR_TBL
UNION
SELECT TRIM(TRAILING FROM f1) FROM CHAR_TBL;
three
-----
a
ab
abcd
three
-----
--
a
ab
abcd
(3 rows)
QUERY:
SELECT f1 AS eight FROM VARCHAR_TBL
SELECT f1 AS eight FROM VARCHAR_TBL
UNION ALL
SELECT f1 FROM CHAR_TBL;
eight
-----
a
ab
abcd
abcd
a
ab
abcd
abcd
eight
-----
--
a
ab
abcd
abcd
a
ab
abcd
abcd
(8 rows)
QUERY:
SELECT f1 AS five FROM TEXT_TBL
SELECT f1 AS five FROM TEXT_TBL
UNION
SELECT f1 FROM VARCHAR_TBL
UNION
SELECT TRIM(TRAILING FROM f1) FROM CHAR_TBL;
five
-----------------
a
ab
abcd
doh!
hi de ho neighbor
five
-----------------
--
a
ab
abcd
doh!
hi de ho neighbor
(5 rows)
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment