mirror of
https://github.com/postgres/postgres.git
synced 2025-04-24 10:47:04 +03:00
Add many new test cases.
This commit is contained in:
parent
dfdb2e5fb0
commit
4335a3779b
@ -1,94 +1,201 @@
|
|||||||
QUERY: SELECT '' AS "One",
|
QUERY: CREATE TABLE CASE_TBL (
|
||||||
|
i integer,
|
||||||
|
f double precision
|
||||||
|
);
|
||||||
|
QUERY: 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",
|
||||||
CASE
|
CASE
|
||||||
WHEN 1 < 2 THEN 3
|
WHEN 1 < 2 THEN 3
|
||||||
END AS "One only = 3";
|
END AS "Simple WHEN";
|
||||||
One|One only = 3
|
One|Simple WHEN
|
||||||
|
---+-----------
|
||||||
|
3| 3
|
||||||
|
(1 row)
|
||||||
|
|
||||||
|
QUERY: SELECT '<NULL>' AS "One",
|
||||||
|
CASE
|
||||||
|
WHEN 1 > 2 THEN 3
|
||||||
|
END AS "Simple default";
|
||||||
|
One |Simple default
|
||||||
|
------+--------------
|
||||||
|
<NULL>|
|
||||||
|
(1 row)
|
||||||
|
|
||||||
|
QUERY: SELECT '3' AS "One",
|
||||||
|
CASE
|
||||||
|
WHEN 1 < 2 THEN 3
|
||||||
|
ELSE 4
|
||||||
|
END AS "Simple ELSE";
|
||||||
|
One|Simple ELSE
|
||||||
|
---+-----------
|
||||||
|
3| 3
|
||||||
|
(1 row)
|
||||||
|
|
||||||
|
QUERY: SELECT '4' AS "One",
|
||||||
|
CASE
|
||||||
|
WHEN 1 > 2 THEN 3
|
||||||
|
ELSE 4
|
||||||
|
END AS "ELSE default";
|
||||||
|
One|ELSE default
|
||||||
---+------------
|
---+------------
|
||||||
| 3
|
4| 4
|
||||||
(1 row)
|
(1 row)
|
||||||
|
|
||||||
QUERY: SELECT '' AS "One",
|
QUERY: SELECT '6' AS "One",
|
||||||
CASE
|
|
||||||
WHEN 1 > 2 THEN 3
|
|
||||||
END AS "One only = Null";
|
|
||||||
One|One only = Null
|
|
||||||
---+---------------
|
|
||||||
|
|
|
||||||
(1 row)
|
|
||||||
|
|
||||||
QUERY: SELECT '' AS "One",
|
|
||||||
CASE
|
|
||||||
WHEN 1 < 2 THEN 3
|
|
||||||
ELSE 4
|
|
||||||
END AS "One with default = 3";
|
|
||||||
One|One with default = 3
|
|
||||||
---+--------------------
|
|
||||||
| 3
|
|
||||||
(1 row)
|
|
||||||
|
|
||||||
QUERY: SELECT '' AS "One",
|
|
||||||
CASE
|
|
||||||
WHEN 1 > 2 THEN 3
|
|
||||||
ELSE 4
|
|
||||||
END AS "One with default = 4";
|
|
||||||
One|One with default = 4
|
|
||||||
---+--------------------
|
|
||||||
| 4
|
|
||||||
(1 row)
|
|
||||||
|
|
||||||
QUERY: SELECT '' AS "One",
|
|
||||||
CASE
|
CASE
|
||||||
WHEN 1 > 2 THEN 3
|
WHEN 1 > 2 THEN 3
|
||||||
WHEN 4 < 5 THEN 6
|
WHEN 4 < 5 THEN 6
|
||||||
ELSE 7
|
ELSE 7
|
||||||
END AS "Two with default = 6";
|
END AS "Two WHEN with default";
|
||||||
One|Two with default = 6
|
One|Two WHEN with default
|
||||||
---+--------------------
|
---+---------------------
|
||||||
| 6
|
6| 6
|
||||||
(1 row)
|
(1 row)
|
||||||
|
|
||||||
QUERY: SELECT '' AS "Five",
|
QUERY: SELECT '' AS "Five",
|
||||||
CASE
|
CASE
|
||||||
WHEN f1 >= 0 THEN f1
|
WHEN i >= 0 THEN i
|
||||||
END AS ">= 0 or Null"
|
END AS ">= 0 or Null"
|
||||||
FROM INT4_TBL;
|
FROM CASE_TBL;
|
||||||
Five|>= 0 or Null
|
Five|>= 0 or Null
|
||||||
----+------------
|
----+------------
|
||||||
| 0
|
| 1
|
||||||
| 123456
|
| 2
|
||||||
|
|
| 3
|
||||||
| 2147483647
|
| 4
|
||||||
|
|
(4 rows)
|
||||||
(5 rows)
|
|
||||||
|
|
||||||
QUERY: SELECT '' AS "Five",
|
QUERY: SELECT '' AS "Five",
|
||||||
CASE WHEN f1 >= 0 THEN (f1 - f1)
|
CASE WHEN i >= 0 THEN (i - i)
|
||||||
ELSE f1
|
ELSE i
|
||||||
END AS "Simplest Math"
|
END AS "Simplest Math"
|
||||||
FROM INT4_TBL;
|
FROM CASE_TBL;
|
||||||
Five|Simplest Math
|
Five|Simplest Math
|
||||||
----+-------------
|
----+-------------
|
||||||
| 0
|
| 0
|
||||||
| 0
|
| 0
|
||||||
| -123456
|
|
||||||
| 0
|
| 0
|
||||||
| -2147483647
|
| 0
|
||||||
(5 rows)
|
(4 rows)
|
||||||
|
|
||||||
QUERY: SELECT '' AS "Five", f1 AS "Value",
|
QUERY: SELECT '' AS "Five", i AS "Value",
|
||||||
CASE WHEN (f1 < 0) THEN 'small'
|
CASE WHEN (i < 0) THEN 'small'
|
||||||
WHEN (f1 = 0) THEN 'zero'
|
WHEN (i = 0) THEN 'zero'
|
||||||
WHEN (f1 = 1) THEN 'one'
|
WHEN (i = 1) THEN 'one'
|
||||||
WHEN (f1 = 2) THEN 'two'
|
WHEN (i = 2) THEN 'two'
|
||||||
ELSE 'big'
|
ELSE 'big'
|
||||||
END AS "Category"
|
END AS "Category"
|
||||||
FROM INT4_TBL;
|
FROM CASE_TBL;
|
||||||
Five| Value|Category
|
Five|Value|Category
|
||||||
----+-----------+--------
|
----+-----+--------
|
||||||
| 0|zero
|
| 1|one
|
||||||
| 123456|big
|
| 2|two
|
||||||
| -123456|small
|
| 3|big
|
||||||
| 2147483647|big
|
| 4|big
|
||||||
|-2147483647|small
|
(4 rows)
|
||||||
(5 rows)
|
|
||||||
|
|
||||||
|
QUERY: /*
|
||||||
|
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'
|
||||||
|
WHEN ((i = 2) or (i = 2)) THEN 'two'
|
||||||
|
ELSE 'big'
|
||||||
|
END AS "Category"
|
||||||
|
FROM CASE_TBL;
|
||||||
|
*/
|
||||||
|
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
|
||||||
|
-+-
|
||||||
|
(0 rows)
|
||||||
|
|
||||||
|
QUERY: /*
|
||||||
|
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;
|
||||||
|
*/
|
||||||
|
SELECT *
|
||||||
|
FROM CASE_TBL a, CASE2_TBL b
|
||||||
|
WHERE COALESCE(a.i, a.f, b.i, b.j) = 4;
|
||||||
|
i|f|i| j
|
||||||
|
-+-+-+--
|
||||||
|
4| |1|-1
|
||||||
|
4| |2|-2
|
||||||
|
4| |3|-3
|
||||||
|
4| |2|-4
|
||||||
|
4| |1|
|
||||||
|
4| | |-6
|
||||||
|
(6 rows)
|
||||||
|
|
||||||
|
QUERY: /*
|
||||||
|
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)"
|
||||||
|
FROM CASE_TBL a, CASE2_TBL b;
|
||||||
|
*/
|
||||||
|
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
|
||||||
|
(2 rows)
|
||||||
|
|
||||||
|
QUERY: UPDATE CASE_TBL
|
||||||
|
SET i = CASE WHEN i >= 0 THEN (- i)
|
||||||
|
ELSE (2 * i) END;
|
||||||
|
QUERY: SELECT * FROM CASE_TBL;
|
||||||
|
i| f
|
||||||
|
--+-----
|
||||||
|
-1| 10.1
|
||||||
|
-2| 20.2
|
||||||
|
-3|-30.3
|
||||||
|
-4|
|
||||||
|
(4 rows)
|
||||||
|
|
||||||
|
QUERY: UPDATE CASE_TBL
|
||||||
|
SET i = CASE WHEN i >= 2 THEN (2 * i)
|
||||||
|
ELSE (3 * i) END;
|
||||||
|
QUERY: SELECT * FROM CASE_TBL;
|
||||||
|
i| f
|
||||||
|
---+-----
|
||||||
|
-3| 10.1
|
||||||
|
-6| 20.2
|
||||||
|
-9|-30.3
|
||||||
|
-12|
|
||||||
|
(4 rows)
|
||||||
|
|
||||||
|
QUERY: /*
|
||||||
|
This crashes the backend at the moment...
|
||||||
|
- thomas 1998-12-12
|
||||||
|
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;
|
||||||
|
SELECT * FROM CASE_TBL;
|
||||||
|
*/
|
||||||
|
DROP TABLE CASE_TBL;
|
||||||
|
QUERY: DROP TABLE CASE2_TBL;
|
||||||
|
@ -2,39 +2,62 @@
|
|||||||
-- case.sql
|
-- case.sql
|
||||||
--
|
--
|
||||||
-- Test the case statement
|
-- Test the case statement
|
||||||
|
|
||||||
--
|
|
||||||
-- Simplest examples without involving tables
|
|
||||||
--
|
--
|
||||||
|
|
||||||
SELECT '' AS "One",
|
CREATE TABLE CASE_TBL (
|
||||||
|
i integer,
|
||||||
|
f double precision
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE TABLE CASE2_TBL (
|
||||||
|
i integer,
|
||||||
|
j integer
|
||||||
|
);
|
||||||
|
|
||||||
|
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
|
CASE
|
||||||
WHEN 1 < 2 THEN 3
|
WHEN 1 < 2 THEN 3
|
||||||
END AS "One only = 3";
|
END AS "Simple WHEN";
|
||||||
|
|
||||||
SELECT '' AS "One",
|
SELECT '<NULL>' AS "One",
|
||||||
CASE
|
CASE
|
||||||
WHEN 1 > 2 THEN 3
|
WHEN 1 > 2 THEN 3
|
||||||
END AS "One only = Null";
|
END AS "Simple default";
|
||||||
|
|
||||||
SELECT '' AS "One",
|
SELECT '3' AS "One",
|
||||||
CASE
|
CASE
|
||||||
WHEN 1 < 2 THEN 3
|
WHEN 1 < 2 THEN 3
|
||||||
ELSE 4
|
ELSE 4
|
||||||
END AS "One with default = 3";
|
END AS "Simple ELSE";
|
||||||
|
|
||||||
SELECT '' AS "One",
|
SELECT '4' AS "One",
|
||||||
CASE
|
CASE
|
||||||
WHEN 1 > 2 THEN 3
|
WHEN 1 > 2 THEN 3
|
||||||
ELSE 4
|
ELSE 4
|
||||||
END AS "One with default = 4";
|
END AS "ELSE default";
|
||||||
|
|
||||||
SELECT '' AS "One",
|
SELECT '6' AS "One",
|
||||||
CASE
|
CASE
|
||||||
WHEN 1 > 2 THEN 3
|
WHEN 1 > 2 THEN 3
|
||||||
WHEN 4 < 5 THEN 6
|
WHEN 4 < 5 THEN 6
|
||||||
ELSE 7
|
ELSE 7
|
||||||
END AS "Two with default = 6";
|
END AS "Two WHEN with default";
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Examples of targets involving tables
|
-- Examples of targets involving tables
|
||||||
@ -42,37 +65,105 @@ SELECT '' AS "One",
|
|||||||
|
|
||||||
SELECT '' AS "Five",
|
SELECT '' AS "Five",
|
||||||
CASE
|
CASE
|
||||||
WHEN f1 >= 0 THEN f1
|
WHEN i >= 0 THEN i
|
||||||
END AS ">= 0 or Null"
|
END AS ">= 0 or Null"
|
||||||
FROM INT4_TBL;
|
FROM CASE_TBL;
|
||||||
|
|
||||||
SELECT '' AS "Five",
|
SELECT '' AS "Five",
|
||||||
CASE WHEN f1 >= 0 THEN (f1 - f1)
|
CASE WHEN i >= 0 THEN (i - i)
|
||||||
ELSE f1
|
ELSE i
|
||||||
END AS "Simplest Math"
|
END AS "Simplest Math"
|
||||||
FROM INT4_TBL;
|
FROM CASE_TBL;
|
||||||
|
|
||||||
SELECT '' AS "Five", f1 AS "Value",
|
SELECT '' AS "Five", i AS "Value",
|
||||||
CASE WHEN (f1 < 0) THEN 'small'
|
CASE WHEN (i < 0) THEN 'small'
|
||||||
WHEN (f1 = 0) THEN 'zero'
|
WHEN (i = 0) THEN 'zero'
|
||||||
WHEN (f1 = 1) THEN 'one'
|
WHEN (i = 1) THEN 'one'
|
||||||
WHEN (f1 = 2) THEN 'two'
|
WHEN (i = 2) THEN 'two'
|
||||||
ELSE 'big'
|
ELSE 'big'
|
||||||
END AS "Category"
|
END AS "Category"
|
||||||
FROM INT4_TBL;
|
FROM CASE_TBL;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
SELECT '' AS "Five",
|
SELECT '' AS "Five",
|
||||||
CASE WHEN ((f1 < 0) or (i < 0)) THEN 'small'
|
CASE WHEN ((i < 0) or (i < 0)) THEN 'small'
|
||||||
WHEN ((f1 = 0) or (i = 0)) THEN 'zero'
|
WHEN ((i = 0) or (i = 0)) THEN 'zero'
|
||||||
WHEN ((f1 = 1) or (i = 1)) THEN 'one'
|
WHEN ((i = 1) or (i = 1)) THEN 'one'
|
||||||
WHEN ((f1 = 2) or (i = 2)) THEN 'two'
|
WHEN ((i = 2) or (i = 2)) THEN 'two'
|
||||||
ELSE 'big'
|
ELSE 'big'
|
||||||
END AS "Category"
|
END AS "Category"
|
||||||
FROM INT4_TBL;
|
FROM CASE_TBL;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Examples of qualifications involving tables
|
-- 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;
|
||||||
|
|
||||||
|
SELECT * FROM CASE_TBL WHERE NULLIF(f,i) = 2;
|
||||||
|
|
||||||
|
/*
|
||||||
|
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;
|
||||||
|
*/
|
||||||
|
|
||||||
|
SELECT *
|
||||||
|
FROM CASE_TBL a, CASE2_TBL b
|
||||||
|
WHERE COALESCE(a.i, a.f, b.i, b.j) = 4;
|
||||||
|
|
||||||
|
/*
|
||||||
|
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)"
|
||||||
|
FROM CASE_TBL a, CASE2_TBL b;
|
||||||
|
*/
|
||||||
|
|
||||||
|
SELECT '' AS "Two", *
|
||||||
|
FROM CASE_TBL a, CASE2_TBL b
|
||||||
|
WHERE COALESCE(f,b.i) = 2;
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Examples of updates involving tables
|
||||||
|
--
|
||||||
|
|
||||||
|
UPDATE CASE_TBL
|
||||||
|
SET i = CASE WHEN i >= 0 THEN (- i)
|
||||||
|
ELSE (2 * i) END;
|
||||||
|
|
||||||
|
SELECT * FROM CASE_TBL;
|
||||||
|
|
||||||
|
UPDATE CASE_TBL
|
||||||
|
SET i = CASE WHEN i >= 2 THEN (2 * i)
|
||||||
|
ELSE (3 * i) END;
|
||||||
|
|
||||||
|
SELECT * FROM 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)
|
||||||
|
ELSE (3 * j) END
|
||||||
|
FROM CASE2_TBL b
|
||||||
|
WHERE j = -CASE_TBL.i;
|
||||||
|
|
||||||
|
SELECT * FROM CASE_TBL;
|
||||||
|
*/
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Clean up
|
||||||
|
--
|
||||||
|
|
||||||
|
DROP TABLE CASE_TBL;
|
||||||
|
DROP TABLE CASE2_TBL;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user