123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269 |
- --
- -- CASE
- -- Test the case statement
- --
- 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
- WHEN 1 < 2 THEN 3
- END AS "Simple WHEN";
- One | Simple WHEN
- -----+-------------
- 3 | 3
- (1 row)
- SELECT '<NULL>' AS "One",
- CASE
- WHEN 1 > 2 THEN 3
- END AS "Simple default";
- One | Simple default
- --------+----------------
- <NULL> |
- (1 row)
- SELECT '3' AS "One",
- CASE
- WHEN 1 < 2 THEN 3
- ELSE 4
- END AS "Simple ELSE";
- One | Simple ELSE
- -----+-------------
- 3 | 3
- (1 row)
- SELECT '4' AS "One",
- CASE
- WHEN 1 > 2 THEN 3
- ELSE 4
- END AS "ELSE default";
- One | ELSE default
- -----+--------------
- 4 | 4
- (1 row)
- 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
- (1 row)
- SELECT '7' AS "None",
- CASE WHEN random() < 0 THEN 1
- END AS "NULL on no matches";
- None | NULL on no matches
- ------+--------------------
- 7 |
- (1 row)
- -- Constant-expression folding shouldn't evaluate unreachable subexpressions
- SELECT CASE WHEN 1=0 THEN 1/0 WHEN 1=1 THEN 1 ELSE 2/0 END;
- case
- ------
- 1
- (1 row)
- SELECT CASE 1 WHEN 0 THEN 1/0 WHEN 1 THEN 1 ELSE 2/0 END;
- case
- ------
- 1
- (1 row)
- -- Test for cases involving untyped literals in test expression
- SELECT CASE 'a' WHEN 'a' THEN 1 ELSE 2 END;
- case
- ------
- 1
- (1 row)
- --
- -- Examples of targets involving tables
- --
- SELECT
- CASE
- WHEN i >= 3 THEN i
- END AS ">= 3 or Null"
- FROM CASE_TBL;
- >= 3 or Null
- --------------
-
-
- 3
- 4
- (4 rows)
- SELECT
- CASE WHEN i >= 3 THEN (i + i)
- ELSE i
- END AS "Simplest Math"
- FROM CASE_TBL;
- Simplest Math
- ---------------
- 1
- 2
- 6
- 8
- (4 rows)
- SELECT i AS "Value",
- CASE WHEN (i < 0) THEN 'small'
- WHEN (i = 0) THEN 'zero'
- WHEN (i = 1) THEN 'one'
- WHEN (i = 2) THEN 'two'
- ELSE 'big'
- END AS "Category"
- FROM CASE_TBL;
- Value | Category
- -------+----------
- 1 | one
- 2 | two
- 3 | big
- 4 | big
- (4 rows)
- SELECT
- 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;
- Category
- ----------
- one
- two
- big
- big
- (4 rows)
- --
- -- Examples of qualifications involving tables
- --
- --
- -- NULLIF() and COALESCE()
- -- Shorthand forms for typical CASE constructs
- -- defined in the SQL standard.
- --
- SELECT * FROM CASE_TBL WHERE COALESCE(f,i) = 4;
- i | f
- ---+---
- 4 |
- (1 row)
- SELECT * FROM CASE_TBL WHERE NULLIF(f,i) = 2;
- i | f
- ---+---
- (0 rows)
- SELECT COALESCE(a.f, b.i, b.j)
- FROM CASE_TBL a, CASE2_TBL b;
- coalesce
- ----------
- 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)
- SELECT 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;
- 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)
- --
- -- Nested CASE expressions
- --
- -- This test exercises a bug caused by aliasing econtext->caseValue_isNull
- -- with the isNull argument of the inner CASE's CaseExpr evaluation. After
- -- evaluating the vol(null) expression in the inner CASE's second WHEN-clause,
- -- the isNull flag for the case test value incorrectly became true, causing
- -- the third WHEN-clause not to match. The volatile function calls are needed
- -- to prevent constant-folding in the planner, which would hide the bug.
- -- Wrap this in a single transaction so the transient '=' operator doesn't
- -- cause problems in concurrent sessions
- BEGIN;
- ROLLBACK;
- -- Test multiple evaluation of a CASE arg that is a read/write object (#14472)
- -- Wrap this in a single transaction so the transient '=' operator doesn't
- -- cause problems in concurrent sessions
- BEGIN;
- ROLLBACK;
- -- Test interaction of CASE with ArrayCoerceExpr (bug #15471)
- BEGIN;
- ROLLBACK;
- --
- -- Clean up
- --
- DROP TABLE CASE_TBL;
- DROP TABLE CASE2_TBL;
|