Update regress test for CASE to enable tests involving joins.
This commit is contained in:
parent
ec1f5f78b9
commit
86bc1da262
|
@ -67,28 +67,28 @@ One|Two WHEN with default
|
||||||
|
|
||||||
QUERY: SELECT '' AS "Five",
|
QUERY: SELECT '' AS "Five",
|
||||||
CASE
|
CASE
|
||||||
WHEN i >= 0 THEN i
|
WHEN i >= 3 THEN i
|
||||||
END AS ">= 0 or Null"
|
END AS ">= 3 or Null"
|
||||||
FROM CASE_TBL;
|
FROM CASE_TBL;
|
||||||
Five|>= 0 or Null
|
Five|>= 3 or Null
|
||||||
----+------------
|
----+------------
|
||||||
| 1
|
|
|
||||||
| 2
|
|
|
||||||
| 3
|
| 3
|
||||||
| 4
|
| 4
|
||||||
(4 rows)
|
(4 rows)
|
||||||
|
|
||||||
QUERY: SELECT '' AS "Five",
|
QUERY: SELECT '' AS "Five",
|
||||||
CASE WHEN i >= 0 THEN (i - i)
|
CASE WHEN i >= 3 THEN (i + i)
|
||||||
ELSE i
|
ELSE i
|
||||||
END AS "Simplest Math"
|
END AS "Simplest Math"
|
||||||
FROM CASE_TBL;
|
FROM CASE_TBL;
|
||||||
Five|Simplest Math
|
Five|Simplest Math
|
||||||
----+-------------
|
----+-------------
|
||||||
| 0
|
| 1
|
||||||
| 0
|
| 2
|
||||||
| 0
|
| 6
|
||||||
| 0
|
| 8
|
||||||
(4 rows)
|
(4 rows)
|
||||||
|
|
||||||
QUERY: SELECT '' AS "Five", i AS "Value",
|
QUERY: SELECT '' AS "Five", i AS "Value",
|
||||||
|
@ -107,8 +107,7 @@ Five|Value|Category
|
||||||
| 4|big
|
| 4|big
|
||||||
(4 rows)
|
(4 rows)
|
||||||
|
|
||||||
QUERY: /*
|
QUERY: SELECT '' AS "Five",
|
||||||
SELECT '' AS "Five",
|
|
||||||
CASE WHEN ((i < 0) or (i < 0)) THEN 'small'
|
CASE WHEN ((i < 0) or (i < 0)) THEN 'small'
|
||||||
WHEN ((i = 0) or (i = 0)) THEN 'zero'
|
WHEN ((i = 0) or (i = 0)) THEN 'zero'
|
||||||
WHEN ((i = 1) or (i = 1)) THEN 'one'
|
WHEN ((i = 1) or (i = 1)) THEN 'one'
|
||||||
|
@ -116,8 +115,15 @@ SELECT '' AS "Five",
|
||||||
ELSE 'big'
|
ELSE 'big'
|
||||||
END AS "Category"
|
END AS "Category"
|
||||||
FROM CASE_TBL;
|
FROM CASE_TBL;
|
||||||
*/
|
Five|Category
|
||||||
SELECT * FROM CASE_TBL WHERE COALESCE(f,i) = 4;
|
----+--------
|
||||||
|
|one
|
||||||
|
|two
|
||||||
|
|big
|
||||||
|
|big
|
||||||
|
(4 rows)
|
||||||
|
|
||||||
|
QUERY: SELECT * FROM CASE_TBL WHERE COALESCE(f,i) = 4;
|
||||||
i|f
|
i|f
|
||||||
-+-
|
-+-
|
||||||
4|
|
4|
|
||||||
|
@ -128,33 +134,77 @@ i|f
|
||||||
-+-
|
-+-
|
||||||
(0 rows)
|
(0 rows)
|
||||||
|
|
||||||
QUERY: /*
|
QUERY: SELECT COALESCE(a.f, b.i, b.j)
|
||||||
This crashes the backend at the moment...
|
|
||||||
- thomas 1998-12-12
|
|
||||||
SELECT COALESCE(a.i, a.f, b.i, b.j)
|
|
||||||
FROM CASE_TBL a, CASE2_TBL b;
|
FROM CASE_TBL a, CASE2_TBL b;
|
||||||
*/
|
case
|
||||||
SELECT *
|
-----
|
||||||
|
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 *
|
||||||
FROM CASE_TBL a, CASE2_TBL b
|
FROM CASE_TBL a, CASE2_TBL b
|
||||||
WHERE COALESCE(a.i, a.f, b.i, b.j) = 4;
|
WHERE COALESCE(a.f, b.i, b.j) = 2;
|
||||||
i|f|i| j
|
i|f|i| j
|
||||||
-+-+-+--
|
-+-+-+--
|
||||||
4| |1|-1
|
|
||||||
4| |2|-2
|
4| |2|-2
|
||||||
4| |3|-3
|
|
||||||
4| |2|-4
|
4| |2|-4
|
||||||
4| |1|
|
(2 rows)
|
||||||
4| | |-6
|
|
||||||
(6 rows)
|
|
||||||
|
|
||||||
QUERY: /*
|
QUERY: SELECT '' AS Five, NULLIF(a.i,b.i) AS "NULLIF(a.i,b.i)",
|
||||||
This crashes the backend at the moment...
|
|
||||||
- thomas 1998-12-12
|
|
||||||
SELECT '' AS Five, NULLIF(a.i,b.i) AS "NULLIF(a.i,b.i)",
|
|
||||||
NULLIF(b.i, 4) AS "NULLIF(b.i,4)"
|
NULLIF(b.i, 4) AS "NULLIF(b.i,4)"
|
||||||
FROM CASE_TBL a, CASE2_TBL b;
|
FROM CASE_TBL a, CASE2_TBL b;
|
||||||
*/
|
five|NULLIF(a.i,b.i)|NULLIF(b.i,4)
|
||||||
SELECT '' AS "Two", *
|
----+---------------+-------------
|
||||||
|
| | 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", *
|
||||||
FROM CASE_TBL a, CASE2_TBL b
|
FROM CASE_TBL a, CASE2_TBL b
|
||||||
WHERE COALESCE(f,b.i) = 2;
|
WHERE COALESCE(f,b.i) = 2;
|
||||||
Two|i|f|i| j
|
Two|i|f|i| j
|
||||||
|
@ -164,13 +214,13 @@ Two|i|f|i| j
|
||||||
(2 rows)
|
(2 rows)
|
||||||
|
|
||||||
QUERY: UPDATE CASE_TBL
|
QUERY: UPDATE CASE_TBL
|
||||||
SET i = CASE WHEN i >= 0 THEN (- i)
|
SET i = CASE WHEN i >= 3 THEN (- i)
|
||||||
ELSE (2 * i) END;
|
ELSE (2 * i) END;
|
||||||
QUERY: SELECT * FROM CASE_TBL;
|
QUERY: SELECT * FROM CASE_TBL;
|
||||||
i| f
|
i| f
|
||||||
--+-----
|
--+-----
|
||||||
-1| 10.1
|
2| 10.1
|
||||||
-2| 20.2
|
4| 20.2
|
||||||
-3|-30.3
|
-3|-30.3
|
||||||
-4|
|
-4|
|
||||||
(4 rows)
|
(4 rows)
|
||||||
|
@ -181,21 +231,25 @@ QUERY: UPDATE CASE_TBL
|
||||||
QUERY: SELECT * FROM CASE_TBL;
|
QUERY: SELECT * FROM CASE_TBL;
|
||||||
i| f
|
i| f
|
||||||
---+-----
|
---+-----
|
||||||
-3| 10.1
|
4| 10.1
|
||||||
-6| 20.2
|
8| 20.2
|
||||||
-9|-30.3
|
-9|-30.3
|
||||||
-12|
|
-12|
|
||||||
(4 rows)
|
(4 rows)
|
||||||
|
|
||||||
QUERY: /*
|
QUERY: UPDATE CASE_TBL
|
||||||
This crashes the backend at the moment...
|
|
||||||
- thomas 1998-12-12
|
|
||||||
UPDATE CASE_TBL
|
|
||||||
SET i = CASE WHEN b.i >= 2 THEN (2 * j)
|
SET i = CASE WHEN b.i >= 2 THEN (2 * j)
|
||||||
ELSE (3 * j) END
|
ELSE (3 * j) END
|
||||||
FROM CASE2_TBL b
|
FROM CASE2_TBL b
|
||||||
WHERE j = -CASE_TBL.i;
|
WHERE j = -CASE_TBL.i;
|
||||||
SELECT * FROM CASE_TBL;
|
QUERY: SELECT * FROM CASE_TBL;
|
||||||
*/
|
i| f
|
||||||
DROP TABLE CASE_TBL;
|
---+-----
|
||||||
|
8| 20.2
|
||||||
|
-9|-30.3
|
||||||
|
-12|
|
||||||
|
-8| 10.1
|
||||||
|
(4 rows)
|
||||||
|
|
||||||
|
QUERY: DROP TABLE CASE_TBL;
|
||||||
QUERY: DROP TABLE CASE2_TBL;
|
QUERY: DROP TABLE CASE2_TBL;
|
||||||
|
|
|
@ -65,12 +65,12 @@ SELECT '6' AS "One",
|
||||||
|
|
||||||
SELECT '' AS "Five",
|
SELECT '' AS "Five",
|
||||||
CASE
|
CASE
|
||||||
WHEN i >= 0 THEN i
|
WHEN i >= 3 THEN i
|
||||||
END AS ">= 0 or Null"
|
END AS ">= 3 or Null"
|
||||||
FROM CASE_TBL;
|
FROM CASE_TBL;
|
||||||
|
|
||||||
SELECT '' AS "Five",
|
SELECT '' AS "Five",
|
||||||
CASE WHEN i >= 0 THEN (i - i)
|
CASE WHEN i >= 3 THEN (i + i)
|
||||||
ELSE i
|
ELSE i
|
||||||
END AS "Simplest Math"
|
END AS "Simplest Math"
|
||||||
FROM CASE_TBL;
|
FROM CASE_TBL;
|
||||||
|
@ -84,7 +84,6 @@ SELECT '' AS "Five", i AS "Value",
|
||||||
END AS "Category"
|
END AS "Category"
|
||||||
FROM CASE_TBL;
|
FROM CASE_TBL;
|
||||||
|
|
||||||
/*
|
|
||||||
SELECT '' AS "Five",
|
SELECT '' AS "Five",
|
||||||
CASE WHEN ((i < 0) or (i < 0)) THEN 'small'
|
CASE WHEN ((i < 0) or (i < 0)) THEN 'small'
|
||||||
WHEN ((i = 0) or (i = 0)) THEN 'zero'
|
WHEN ((i = 0) or (i = 0)) THEN 'zero'
|
||||||
|
@ -93,7 +92,6 @@ SELECT '' AS "Five",
|
||||||
ELSE 'big'
|
ELSE 'big'
|
||||||
END AS "Category"
|
END AS "Category"
|
||||||
FROM CASE_TBL;
|
FROM CASE_TBL;
|
||||||
*/
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Examples of qualifications involving tables
|
-- Examples of qualifications involving tables
|
||||||
|
@ -109,24 +107,16 @@ SELECT * FROM CASE_TBL WHERE COALESCE(f,i) = 4;
|
||||||
|
|
||||||
SELECT * FROM CASE_TBL WHERE NULLIF(f,i) = 2;
|
SELECT * FROM CASE_TBL WHERE NULLIF(f,i) = 2;
|
||||||
|
|
||||||
/*
|
SELECT COALESCE(a.f, b.i, b.j)
|
||||||
This crashes the backend at the moment...
|
|
||||||
- thomas 1998-12-12
|
|
||||||
SELECT COALESCE(a.i, a.f, b.i, b.j)
|
|
||||||
FROM CASE_TBL a, CASE2_TBL b;
|
FROM CASE_TBL a, CASE2_TBL b;
|
||||||
*/
|
|
||||||
|
|
||||||
SELECT *
|
SELECT *
|
||||||
FROM CASE_TBL a, CASE2_TBL b
|
FROM CASE_TBL a, CASE2_TBL b
|
||||||
WHERE COALESCE(a.i, a.f, b.i, b.j) = 4;
|
WHERE COALESCE(a.f, b.i, b.j) = 2;
|
||||||
|
|
||||||
/*
|
|
||||||
This crashes the backend at the moment...
|
|
||||||
- thomas 1998-12-12
|
|
||||||
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)"
|
NULLIF(b.i, 4) AS "NULLIF(b.i,4)"
|
||||||
FROM CASE_TBL a, CASE2_TBL b;
|
FROM CASE_TBL a, CASE2_TBL b;
|
||||||
*/
|
|
||||||
|
|
||||||
SELECT '' AS "Two", *
|
SELECT '' AS "Two", *
|
||||||
FROM CASE_TBL a, CASE2_TBL b
|
FROM CASE_TBL a, CASE2_TBL b
|
||||||
|
@ -137,7 +127,7 @@ SELECT '' AS "Two", *
|
||||||
--
|
--
|
||||||
|
|
||||||
UPDATE CASE_TBL
|
UPDATE CASE_TBL
|
||||||
SET i = CASE WHEN i >= 0 THEN (- i)
|
SET i = CASE WHEN i >= 3 THEN (- i)
|
||||||
ELSE (2 * i) END;
|
ELSE (2 * i) END;
|
||||||
|
|
||||||
SELECT * FROM CASE_TBL;
|
SELECT * FROM CASE_TBL;
|
||||||
|
@ -148,9 +138,6 @@ UPDATE CASE_TBL
|
||||||
|
|
||||||
SELECT * FROM CASE_TBL;
|
SELECT * FROM CASE_TBL;
|
||||||
|
|
||||||
/*
|
|
||||||
This crashes the backend at the moment...
|
|
||||||
- thomas 1998-12-12
|
|
||||||
UPDATE CASE_TBL
|
UPDATE CASE_TBL
|
||||||
SET i = CASE WHEN b.i >= 2 THEN (2 * j)
|
SET i = CASE WHEN b.i >= 2 THEN (2 * j)
|
||||||
ELSE (3 * j) END
|
ELSE (3 * j) END
|
||||||
|
@ -158,7 +145,6 @@ UPDATE CASE_TBL
|
||||||
WHERE j = -CASE_TBL.i;
|
WHERE j = -CASE_TBL.i;
|
||||||
|
|
||||||
SELECT * FROM CASE_TBL;
|
SELECT * FROM CASE_TBL;
|
||||||
*/
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Clean up
|
-- Clean up
|
||||||
|
|
Loading…
Reference in New Issue