]> granicus.if.org Git - postgresql/commitdiff
Include test for CASE expression.
authorThomas G. Lockhart <lockhart@fourpalms.org>
Fri, 4 Dec 1998 15:36:51 +0000 (15:36 +0000)
committerThomas G. Lockhart <lockhart@fourpalms.org>
Fri, 4 Dec 1998 15:36:51 +0000 (15:36 +0000)
src/test/regress/expected/case.out [new file with mode: 0644]
src/test/regress/sql/case.sql [new file with mode: 0644]
src/test/regress/sql/tests

diff --git a/src/test/regress/expected/case.out b/src/test/regress/expected/case.out
new file mode 100644 (file)
index 0000000..5c71461
--- /dev/null
@@ -0,0 +1,94 @@
+QUERY: SELECT '' AS "One",
+  CASE
+    WHEN 1 < 2 THEN 3
+  END AS "One only = 3";
+One|One only = 3
+---+------------
+   |           3
+(1 row)
+
+QUERY: SELECT '' 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
+    WHEN 1 > 2 THEN 3
+    WHEN 4 < 5 THEN 6
+    ELSE 7
+  END AS "Two with default = 6";
+One|Two with default = 6
+---+--------------------
+   |                   6
+(1 row)
+
+QUERY: SELECT '' AS "Five",
+  CASE
+    WHEN f1 >= 0 THEN f1
+  END AS ">= 0 or Null"
+  FROM INT4_TBL;
+Five|>= 0 or Null
+----+------------
+    |           0
+    |      123456
+    |            
+    |  2147483647
+    |            
+(5 rows)
+
+QUERY: SELECT '' AS "Five",
+  CASE WHEN f1 >= 0 THEN (f1 - f1)
+       ELSE f1
+  END AS "Simplest Math"
+  FROM INT4_TBL;
+Five|Simplest Math
+----+-------------
+    |            0
+    |            0
+    |      -123456
+    |            0
+    |  -2147483647
+(5 rows)
+
+QUERY: SELECT '' AS "Five", f1 AS "Value",
+  CASE WHEN (f1 < 0) THEN 'small'
+       WHEN (f1 = 0) THEN 'zero'
+       WHEN (f1 = 1) THEN 'one'
+       WHEN (f1 = 2) THEN 'two'
+       ELSE 'big'
+  END AS "Category"
+  FROM INT4_TBL;
+Five|      Value|Category
+----+-----------+--------
+    |          0|zero    
+    |     123456|big     
+    |    -123456|small   
+    | 2147483647|big     
+    |-2147483647|small   
+(5 rows)
+
diff --git a/src/test/regress/sql/case.sql b/src/test/regress/sql/case.sql
new file mode 100644 (file)
index 0000000..6d4a634
--- /dev/null
@@ -0,0 +1,78 @@
+--
+-- case.sql
+--
+-- Test the case statement
+
+--
+-- Simplest examples without involving tables
+--
+
+SELECT '' AS "One",
+  CASE
+    WHEN 1 < 2 THEN 3
+  END AS "One only = 3";
+
+SELECT '' AS "One",
+  CASE
+    WHEN 1 > 2 THEN 3
+  END AS "One only = Null";
+
+SELECT '' AS "One",
+  CASE
+    WHEN 1 < 2 THEN 3
+    ELSE 4
+  END AS "One with default = 3";
+
+SELECT '' AS "One",
+  CASE
+    WHEN 1 > 2 THEN 3
+    ELSE 4
+  END AS "One with default = 4";
+
+SELECT '' AS "One",
+  CASE
+    WHEN 1 > 2 THEN 3
+    WHEN 4 < 5 THEN 6
+    ELSE 7
+  END AS "Two with default = 6";
+
+--
+-- Examples of targets involving tables
+--
+
+SELECT '' AS "Five",
+  CASE
+    WHEN f1 >= 0 THEN f1
+  END AS ">= 0 or Null"
+  FROM INT4_TBL;
+
+SELECT '' AS "Five",
+  CASE WHEN f1 >= 0 THEN (f1 - f1)
+       ELSE f1
+  END AS "Simplest Math"
+  FROM INT4_TBL;
+
+SELECT '' AS "Five", f1 AS "Value",
+  CASE WHEN (f1 < 0) THEN 'small'
+       WHEN (f1 = 0) THEN 'zero'
+       WHEN (f1 = 1) THEN 'one'
+       WHEN (f1 = 2) THEN 'two'
+       ELSE 'big'
+  END AS "Category"
+  FROM INT4_TBL;
+
+/*
+SELECT '' AS "Five",
+  CASE WHEN ((f1 < 0) or (i < 0)) THEN 'small'
+       WHEN ((f1 = 0) or (i = 0)) THEN 'zero'
+       WHEN ((f1 = 1) or (i = 1)) THEN 'one'
+       WHEN ((f1 = 2) or (i = 2)) THEN 'two'
+       ELSE 'big'
+  END AS "Category"
+  FROM INT4_TBL;
+*/
+
+--
+-- Examples of qualifications involving tables
+--
+
index 1780d95be4a52630aa82df20ea3d8325157fe135..3c3d30b9496c9d1ef727e1f6273eeda0369fcd51 100644 (file)
@@ -49,6 +49,7 @@ select_implicit
 select_having
 subselect
 union
+case
 aggregates
 transactions
 random