postgresql/src/test/regress/expected/case.out

280 lines
5.5 KiB
Plaintext
Raw Normal View History

2000-01-06 07:40:54 +01:00
--
-- CASE
-- Test the case statement
--
CREATE TABLE CASE_TBL (
1999-02-23 08:30:05 +01:00
i integer,
f double precision
);
2000-01-06 07:40:54 +01:00
CREATE TABLE CASE2_TBL (
1999-02-23 08:30:05 +01:00
i integer,
j integer
);
2000-01-06 07:40:54 +01:00
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",
1998-12-04 16:36:51 +01:00
CASE
WHEN 1 < 2 THEN 3
1999-02-23 08:30:05 +01:00
END AS "Simple WHEN";
2000-01-06 07:40:54 +01:00
One | Simple WHEN
-----+-------------
3 | 3
1998-12-04 16:36:51 +01:00
(1 row)
2000-01-06 07:40:54 +01:00
SELECT '<NULL>' AS "One",
1998-12-04 16:36:51 +01:00
CASE
WHEN 1 > 2 THEN 3
1999-02-23 08:30:05 +01:00
END AS "Simple default";
2000-01-06 07:40:54 +01:00
One | Simple default
--------+----------------
<NULL> |
1998-12-04 16:36:51 +01:00
(1 row)
2000-01-06 07:40:54 +01:00
SELECT '3' AS "One",
1998-12-04 16:36:51 +01:00
CASE
WHEN 1 < 2 THEN 3
ELSE 4
1999-02-23 08:30:05 +01:00
END AS "Simple ELSE";
2000-01-06 07:40:54 +01:00
One | Simple ELSE
-----+-------------
3 | 3
1998-12-04 16:36:51 +01:00
(1 row)
2000-01-06 07:40:54 +01:00
SELECT '4' AS "One",
1998-12-04 16:36:51 +01:00
CASE
WHEN 1 > 2 THEN 3
ELSE 4
1999-02-23 08:30:05 +01:00
END AS "ELSE default";
2000-01-06 07:40:54 +01:00
One | ELSE default
-----+--------------
4 | 4
1998-12-04 16:36:51 +01:00
(1 row)
2000-01-06 07:40:54 +01:00
SELECT '6' AS "One",
1998-12-04 16:36:51 +01:00
CASE
WHEN 1 > 2 THEN 3
WHEN 4 < 5 THEN 6
ELSE 7
1999-02-23 08:30:05 +01:00
END AS "Two WHEN with default";
2000-01-06 07:40:54 +01:00
One | Two WHEN with default
-----+-----------------------
6 | 6
1998-12-04 16:36:51 +01:00
(1 row)
2000-01-06 07:40:54 +01:00
--
-- Examples of targets involving tables
--
SELECT '' AS "Five",
1998-12-04 16:36:51 +01:00
CASE
WHEN i >= 3 THEN i
END AS ">= 3 or Null"
1999-02-23 08:30:05 +01:00
FROM CASE_TBL;
2000-01-06 07:40:54 +01:00
Five | >= 3 or Null
------+--------------
|
|
| 3
| 4
1999-02-23 08:30:05 +01:00
(4 rows)
1998-12-04 16:36:51 +01:00
2000-01-06 07:40:54 +01:00
SELECT '' AS "Five",
CASE WHEN i >= 3 THEN (i + i)
1999-02-23 08:30:05 +01:00
ELSE i
1998-12-04 16:36:51 +01:00
END AS "Simplest Math"
1999-02-23 08:30:05 +01:00
FROM CASE_TBL;
2000-01-06 07:40:54 +01:00
Five | Simplest Math
------+---------------
| 1
| 2
| 6
| 8
1999-02-23 08:30:05 +01:00
(4 rows)
2000-01-06 07:40:54 +01:00
SELECT '' AS "Five", i AS "Value",
1999-02-23 08:30:05 +01:00
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;
2000-01-06 07:40:54 +01:00
Five | Value | Category
------+-------+----------
| 1 | one
| 2 | two
| 3 | big
| 4 | big
1999-02-23 08:30:05 +01:00
(4 rows)
1998-12-04 16:36:51 +01:00
2000-01-06 07:40:54 +01:00
SELECT '' AS "Five",
1999-02-23 08:30:05 +01:00
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'
1998-12-04 16:36:51 +01:00
ELSE 'big'
END AS "Category"
1999-02-23 08:30:05 +01:00
FROM CASE_TBL;
2000-01-06 07:40:54 +01:00
Five | Category
------+----------
| one
| two
| big
| big
(4 rows)
2000-01-06 07:40:54 +01:00
--
-- 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 |
1999-02-23 08:30:05 +01:00
(1 row)
2000-01-06 07:40:54 +01:00
SELECT * FROM CASE_TBL WHERE NULLIF(f,i) = 2;
i | f
---+---
1999-02-23 08:30:05 +01:00
(0 rows)
2000-01-06 07:40:54 +01:00
SELECT COALESCE(a.f, b.i, b.j)
1999-02-23 08:30:05 +01:00
FROM CASE_TBL a, CASE2_TBL b;
coalesce
----------
10.1
10.1
10.1
10.1
10.1
10.1
20.2
20.2
20.2
20.2
20.2
20.2
-30.3
-30.3
-30.3
-30.3
-30.3
-30.3
1
2
3
2
1
-6
(24 rows)
2000-01-06 07:40:54 +01:00
SELECT *
1999-02-23 08:30:05 +01:00
FROM CASE_TBL a, CASE2_TBL b
WHERE COALESCE(a.f, b.i, b.j) = 2;
2000-01-06 07:40:54 +01:00
i | f | i | j
---+---+---+----
4 | | 2 | -2
4 | | 2 | -4
(2 rows)
2000-01-06 07:40:54 +01:00
SELECT '' AS Five, NULLIF(a.i,b.i) AS "NULLIF(a.i,b.i)",
1999-02-23 08:30:05 +01:00
NULLIF(b.i, 4) AS "NULLIF(b.i,4)"
FROM CASE_TBL a, CASE2_TBL b;
2000-01-06 07:40:54 +01:00
five | NULLIF(a.i,b.i) | NULLIF(b.i,4)
------+-----------------+---------------
| | 1
| 1 | 2
| 1 | 3
| 1 | 2
| | 1
| 1 |
| 2 | 1
| | 2
| 2 | 3
| | 2
| 2 | 1
2000-01-06 07:40:54 +01:00
| 2 |
| 3 | 1
| 3 | 2
| | 3
| 3 | 2
| 3 | 1
2000-01-06 07:40:54 +01:00
| 3 |
| 4 | 1
| 4 | 2
| 4 | 3
| 4 | 2
| 4 | 1
2000-01-06 07:40:54 +01:00
| 4 |
(24 rows)
2000-01-06 07:40:54 +01:00
SELECT '' AS "Two", *
1999-02-23 08:30:05 +01:00
FROM CASE_TBL a, CASE2_TBL b
WHERE COALESCE(f,b.i) = 2;
2000-01-06 07:40:54 +01:00
Two | i | f | i | j
-----+---+---+---+----
| 4 | | 2 | -2
| 4 | | 2 | -4
1999-02-23 08:30:05 +01:00
(2 rows)
2000-01-06 07:40:54 +01:00
--
-- Examples of updates involving tables
--
UPDATE CASE_TBL
SET i = CASE WHEN i >= 3 THEN (- i)
1999-02-23 08:30:05 +01:00
ELSE (2 * i) END;
2000-01-06 07:40:54 +01:00
SELECT * FROM CASE_TBL;
i | f
----+-------
2 | 10.1
4 | 20.2
-3 | -30.3
-4 |
1999-02-23 08:30:05 +01:00
(4 rows)
2000-01-06 07:40:54 +01:00
UPDATE CASE_TBL
1999-02-23 08:30:05 +01:00
SET i = CASE WHEN i >= 2 THEN (2 * i)
ELSE (3 * i) END;
2000-01-06 07:40:54 +01:00
SELECT * FROM CASE_TBL;
i | f
-----+-------
4 | 10.1
8 | 20.2
-9 | -30.3
-12 |
1999-02-23 08:30:05 +01:00
(4 rows)
1998-12-04 16:36:51 +01:00
2000-01-06 07:40:54 +01:00
UPDATE CASE_TBL
1999-02-23 08:30:05 +01:00
SET i = CASE WHEN b.i >= 2 THEN (2 * j)
ELSE (3 * j) END
FROM CASE2_TBL b
WHERE j = -CASE_TBL.i;
2000-01-06 07:40:54 +01:00
SELECT * FROM CASE_TBL;
i | f
-----+-------
8 | 20.2
-9 | -30.3
-12 |
-8 | 10.1
(4 rows)
2000-01-06 07:40:54 +01:00
--
-- Clean up
--
DROP TABLE CASE_TBL;
DROP TABLE CASE2_TBL;