select_implicit.sql
上传用户:blenddy
上传日期:2007-01-07
资源大小:6495k
文件大小:5k
源码类别:

数据库系统

开发平台:

Unix_Linux

  1. --
  2. -- select_implicit.sql
  3. --
  4. -- Test cases for queries with ordering terms missing from the target list.
  5. -- This used to be called "junkfilter.sql".
  6. -- The parser uses the term "resjunk" to handle these cases.
  7. -- - thomas 1998-07-09
  8. -- load test data
  9. CREATE TABLE test_missing_target (a int, b int, c char(8), d char);
  10. INSERT INTO test_missing_target VALUES (0, 1, 'XXXX', 'A');
  11. INSERT INTO test_missing_target VALUES (1, 2, 'AAAA', 'b');
  12. INSERT INTO test_missing_target VALUES (2, 2, 'AAAA', 'c');
  13. INSERT INTO test_missing_target VALUES (3, 3, 'BBBB', 'D');
  14. INSERT INTO test_missing_target VALUES (4, 3, 'BBBB', 'e');
  15. INSERT INTO test_missing_target VALUES (5, 3, 'bbbb', 'F');
  16. INSERT INTO test_missing_target VALUES (6, 4, 'cccc', 'g');
  17. INSERT INTO test_missing_target VALUES (7, 4, 'cccc', 'h');
  18. INSERT INTO test_missing_target VALUES (8, 4, 'CCCC', 'I');
  19. INSERT INTO test_missing_target VALUES (9, 4, 'CCCC', 'j');
  20. --   w/ existing GROUP BY target
  21. SELECT c, count(*) FROM test_missing_target GROUP BY test_missing_target.c;
  22. --   w/o existing GROUP BY target using a relation name in GROUP BY clause
  23. SELECT count(*) FROM test_missing_target GROUP BY test_missing_target.c;
  24. --   w/o existing GROUP BY target and w/o existing a different ORDER BY target
  25. --   failure expected
  26. SELECT count(*) FROM test_missing_target GROUP BY a ORDER BY b;
  27. --   w/o existing GROUP BY target and w/o existing same ORDER BY target
  28. SELECT count(*) FROM test_missing_target GROUP BY b ORDER BY b;
  29. --   w/ existing GROUP BY target using a relation name in target
  30. SELECT test_missing_target.b, count(*)
  31.   FROM test_missing_target GROUP BY b ORDER BY b;
  32. --   w/o existing GROUP BY target
  33. SELECT c FROM test_missing_target ORDER BY a;
  34. --   w/o existing ORDER BY target
  35. SELECT count(*) FROM test_missing_target GROUP BY b ORDER BY b desc;
  36. --   group using reference number
  37. SELECT count(*) FROM test_missing_target ORDER BY 1 desc;
  38. --   order using reference number
  39. SELECT c, count(*) FROM test_missing_target GROUP BY 1;
  40. --   group using reference number out of range
  41. --   failure expected
  42. SELECT c, count(*) FROM test_missing_target GROUP BY 3;
  43. --   group w/o existing GROUP BY and ORDER BY target under ambiguous condition
  44. --   failure expected
  45. SELECT count(*) FROM test_missing_target x, test_missing_target y 
  46. WHERE x.a = y.a
  47. GROUP BY b ORDER BY b;
  48. --   order w/ target under ambiguous condition
  49. --   failure NOT expected
  50. SELECT a, a FROM test_missing_target
  51. ORDER BY a;
  52. --   order expression w/ target under ambiguous condition
  53. --   failure NOT expected
  54. SELECT a/2, a/2 FROM test_missing_target
  55. ORDER BY a/2;
  56. --   group expression w/ target under ambiguous condition
  57. --   failure NOT expected
  58. SELECT a/2, a/2 FROM test_missing_target
  59. GROUP BY a/2;
  60. --   group w/ existing GROUP BY target under ambiguous condition
  61. SELECT x.b, count(*) FROM test_missing_target x, test_missing_target y 
  62. WHERE x.a = y.a
  63. GROUP BY x.b;
  64. --   group w/o existing GROUP BY target under ambiguous condition
  65. SELECT count(*) FROM test_missing_target x, test_missing_target y 
  66. WHERE x.a = y.a
  67. GROUP BY x.b;
  68. --   group w/o existing GROUP BY target under ambiguous condition
  69. --   into a table
  70. SELECT count(*) INTO TABLE test_missing_target2 
  71. FROM test_missing_target x, test_missing_target y 
  72. WHERE x.a = y.a
  73. GROUP BY x.b;
  74. SELECT * FROM test_missing_target2;
  75. --  Functions and expressions
  76. --   w/ existing GROUP BY target
  77. SELECT a%2, count(a) FROM test_missing_target GROUP BY test_missing_target.a%2;
  78. --   w/o existing GROUP BY target using a relation name in GROUP BY clause
  79. SELECT count(c) FROM test_missing_target GROUP BY lower(test_missing_target.c);
  80. --   w/o existing GROUP BY target and w/o existing a different ORDER BY target
  81. --   failure expected
  82. SELECT count(a) FROM test_missing_target GROUP BY a ORDER BY b;
  83. --   w/o existing GROUP BY target and w/o existing same ORDER BY target
  84. SELECT count(b) FROM test_missing_target GROUP BY b/2 ORDER BY b/2;
  85. --   w/ existing GROUP BY target using a relation name in target
  86. SELECT lower(test_missing_target.c), count(c)
  87.   FROM test_missing_target GROUP BY lower(c) ORDER BY lower(c);
  88. --   w/o existing GROUP BY target
  89. SELECT a FROM test_missing_target ORDER BY upper(d);
  90. --   w/o existing ORDER BY target
  91. SELECT count(b) FROM test_missing_target
  92. GROUP BY (b + 1) / 2 ORDER BY (b + 1) / 2 desc;
  93. --   group w/o existing GROUP BY and ORDER BY target under ambiguous condition
  94. --   failure expected
  95. SELECT count(x.a) FROM test_missing_target x, test_missing_target y 
  96. WHERE x.a = y.a
  97. GROUP BY b/2 ORDER BY b/2;
  98. --   group w/ existing GROUP BY target under ambiguous condition
  99. SELECT x.b/2, count(x.b) FROM test_missing_target x, test_missing_target y 
  100. WHERE x.a = y.a
  101. GROUP BY x.b/2;
  102. --   group w/o existing GROUP BY target under ambiguous condition
  103. --   failure expected due to ambiguous b in count(b)
  104. SELECT count(b) FROM test_missing_target x, test_missing_target y 
  105. WHERE x.a = y.a
  106. GROUP BY x.b/2;
  107. --   group w/o existing GROUP BY target under ambiguous condition
  108. --   into a table
  109. SELECT count(x.b) INTO TABLE test_missing_target3 
  110. FROM test_missing_target x, test_missing_target y 
  111. WHERE x.a = y.a
  112. GROUP BY x.b/2;
  113. SELECT * FROM test_missing_target3;
  114. --   Cleanup
  115. DROP TABLE test_missing_target;
  116. DROP TABLE test_missing_target2;
  117. DROP TABLE test_missing_target3;