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

数据库系统

开发平台:

Unix_Linux

  1. QUERY: SELECT 1 AS one WHERE 1 IN (SELECT 1);
  2. one
  3. ---
  4.   1
  5. (1 row)
  6. QUERY: SELECT 1 AS zero WHERE 1 NOT IN (SELECT 1);
  7. zero
  8. ----
  9. (0 rows)
  10. QUERY: SELECT 1 AS zero WHERE 1 IN (SELECT 2);
  11. zero
  12. ----
  13. (0 rows)
  14. QUERY: CREATE TABLE SUBSELECT_TBL (
  15.   f1 integer,
  16.   f2 integer,
  17.   f3 float
  18. );
  19. QUERY: INSERT INTO SUBSELECT_TBL VALUES (1, 2, 3);
  20. QUERY: INSERT INTO SUBSELECT_TBL VALUES (2, 3, 4);
  21. QUERY: INSERT INTO SUBSELECT_TBL VALUES (3, 4, 5);
  22. QUERY: INSERT INTO SUBSELECT_TBL VALUES (1, 1, 1);
  23. QUERY: INSERT INTO SUBSELECT_TBL VALUES (2, 2, 2);
  24. QUERY: INSERT INTO SUBSELECT_TBL VALUES (3, 3, 3);
  25. QUERY: INSERT INTO SUBSELECT_TBL VALUES (6, 7, 8);
  26. QUERY: INSERT INTO SUBSELECT_TBL VALUES (8, 9, NULL);
  27. QUERY: SELECT '' AS eight, * FROM SUBSELECT_TBL;
  28. eight|f1|f2|f3
  29. -----+--+--+--
  30.      | 1| 2| 3
  31.      | 2| 3| 4
  32.      | 3| 4| 5
  33.      | 1| 1| 1
  34.      | 2| 2| 2
  35.      | 3| 3| 3
  36.      | 6| 7| 8
  37.      | 8| 9|  
  38. (8 rows)
  39. QUERY: SELECT '' AS two, f1 AS "Constant Select" FROM SUBSELECT_TBL
  40.   WHERE f1 IN (SELECT 1);
  41. two|Constant Select
  42. ---+---------------
  43.    |              1
  44.    |              1
  45. (2 rows)
  46. QUERY: SELECT '' AS six, f1 AS "Uncorrelated Field" FROM SUBSELECT_TBL
  47.   WHERE f1 IN (SELECT f2 FROM SUBSELECT_TBL);
  48. six|Uncorrelated Field
  49. ---+------------------
  50.    |                 1
  51.    |                 2
  52.    |                 3
  53.    |                 1
  54.    |                 2
  55.    |                 3
  56. (6 rows)
  57. QUERY: SELECT '' AS six, f1 AS "Uncorrelated Field" FROM SUBSELECT_TBL
  58.   WHERE f1 IN (SELECT f2 FROM SUBSELECT_TBL WHERE
  59.     f2 IN (SELECT f1 FROM SUBSELECT_TBL));
  60. six|Uncorrelated Field
  61. ---+------------------
  62.    |                 1
  63.    |                 2
  64.    |                 3
  65.    |                 1
  66.    |                 2
  67.    |                 3
  68. (6 rows)
  69. QUERY: SELECT '' AS six, f1 AS "Correlated Field", f3 AS "Second Field"
  70.   FROM SUBSELECT_TBL
  71.   WHERE f1 IN (SELECT f2 FROM SUBSELECT_TBL WHERE f2 = f1);
  72. six|Correlated Field|Second Field
  73. ---+----------------+------------
  74.    |               1|           3
  75.    |               2|           4
  76.    |               3|           5
  77.    |               1|           1
  78.    |               2|           2
  79.    |               3|           3
  80. (6 rows)
  81. QUERY: SELECT '' AS six, f1 AS "Correlated Field", f3 AS "Second Field"
  82.   FROM SUBSELECT_TBL
  83.   WHERE f1 IN (SELECT f2 FROM SUBSELECT_TBL WHERE CAST(f2 AS float) = f3);
  84. six|Correlated Field|Second Field
  85. ---+----------------+------------
  86.    |               1|           3
  87.    |               2|           4
  88.    |               3|           5
  89.    |               1|           1
  90.    |               2|           2
  91.    |               3|           3
  92. (6 rows)
  93. QUERY: SELECT '' AS six, f1 AS "Correlated Field", f3 AS "Second Field"
  94.   FROM SUBSELECT_TBL
  95.   WHERE f1 IN (SELECT f2 FROM SUBSELECT_TBL WHERE f2 = CAST(f3 AS integer));
  96. ERROR:  dtoi4: unable to convert null
  97. QUERY: SELECT '' AS five, f1 AS "Correlated Field"
  98.   FROM SUBSELECT_TBL
  99.   WHERE (f1, f2) IN (SELECT f2, CAST(f3 AS int4) FROM SUBSELECT_TBL WHERE f3 IS NOT NULL);
  100. five|Correlated Field
  101. ----+----------------
  102.     |               2
  103.     |               3
  104.     |               1
  105.     |               2
  106.     |               3
  107. (5 rows)
  108. QUERY: SELECT '' AS three, f1 AS "Correlated Field"
  109.   FROM SUBSELECT_TBL
  110.   WHERE (f1, f2) NOT IN (SELECT f2, CAST(f3 AS int4) FROM SUBSELECT_TBL WHERE f3 IS NOT NULL);
  111. three|Correlated Field
  112. -----+----------------
  113.      |               1
  114.      |               6
  115.      |               8
  116. (3 rows)
  117. QUERY: SELECT '' AS eight, ss.f1 AS "Correlated Field", ss.f3 AS "Second Field"
  118.   FROM SUBSELECT_TBL ss
  119.   WHERE f1 NOT IN (SELECT f1 FROM INT4_TBL WHERE f1 != ss.f1);
  120. eight|Correlated Field|Second Field
  121. -----+----------------+------------
  122.      |               1|           3
  123.      |               2|           4
  124.      |               3|           5
  125.      |               1|           1
  126.      |               2|           2
  127.      |               3|           3
  128.      |               6|           8
  129.      |               8|            
  130. (8 rows)