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

数据库系统

开发平台:

Unix_Linux

  1. --
  2. -- Subselects
  3. --
  4. SELECT 1 AS one WHERE 1 IN (SELECT 1);
  5. SELECT 1 AS zero WHERE 1 NOT IN (SELECT 1);
  6. SELECT 1 AS zero WHERE 1 IN (SELECT 2);
  7. -- Set up some simple test tables
  8. CREATE TABLE SUBSELECT_TBL (
  9.   f1 integer,
  10.   f2 integer,
  11.   f3 float
  12. );
  13. INSERT INTO SUBSELECT_TBL VALUES (1, 2, 3);
  14. INSERT INTO SUBSELECT_TBL VALUES (2, 3, 4);
  15. INSERT INTO SUBSELECT_TBL VALUES (3, 4, 5);
  16. INSERT INTO SUBSELECT_TBL VALUES (1, 1, 1);
  17. INSERT INTO SUBSELECT_TBL VALUES (2, 2, 2);
  18. INSERT INTO SUBSELECT_TBL VALUES (3, 3, 3);
  19. INSERT INTO SUBSELECT_TBL VALUES (6, 7, 8);
  20. INSERT INTO SUBSELECT_TBL VALUES (8, 9, NULL);
  21. SELECT '' AS eight, * FROM SUBSELECT_TBL;
  22. -- Uncorrelated subselects
  23. SELECT '' AS two, f1 AS "Constant Select" FROM SUBSELECT_TBL
  24.   WHERE f1 IN (SELECT 1);
  25. SELECT '' AS six, f1 AS "Uncorrelated Field" FROM SUBSELECT_TBL
  26.   WHERE f1 IN (SELECT f2 FROM SUBSELECT_TBL);
  27. SELECT '' AS six, f1 AS "Uncorrelated Field" FROM SUBSELECT_TBL
  28.   WHERE f1 IN (SELECT f2 FROM SUBSELECT_TBL WHERE
  29.     f2 IN (SELECT f1 FROM SUBSELECT_TBL));
  30. -- Correlated subselects
  31. SELECT '' AS six, f1 AS "Correlated Field", f3 AS "Second Field"
  32.   FROM SUBSELECT_TBL
  33.   WHERE f1 IN (SELECT f2 FROM SUBSELECT_TBL WHERE f2 = f1);
  34. SELECT '' AS six, f1 AS "Correlated Field", f3 AS "Second Field"
  35.   FROM SUBSELECT_TBL
  36.   WHERE f1 IN (SELECT f2 FROM SUBSELECT_TBL WHERE CAST(f2 AS float) = f3);
  37. SELECT '' AS six, f1 AS "Correlated Field", f3 AS "Second Field"
  38.   FROM SUBSELECT_TBL
  39.   WHERE f1 IN (SELECT f2 FROM SUBSELECT_TBL WHERE f2 = CAST(f3 AS integer));
  40. SELECT '' AS five, f1 AS "Correlated Field"
  41.   FROM SUBSELECT_TBL
  42.   WHERE (f1, f2) IN (SELECT f2, CAST(f3 AS int4) FROM SUBSELECT_TBL WHERE f3 IS NOT NULL);
  43. SELECT '' AS three, f1 AS "Correlated Field"
  44.   FROM SUBSELECT_TBL
  45.   WHERE (f1, f2) NOT IN (SELECT f2, CAST(f3 AS int4) FROM SUBSELECT_TBL WHERE f3 IS NOT NULL);
  46. --
  47. -- Use some existing tables in the regression test
  48. --
  49. SELECT '' AS eight, ss.f1 AS "Correlated Field", ss.f3 AS "Second Field"
  50.   FROM SUBSELECT_TBL ss
  51.   WHERE f1 NOT IN (SELECT f1 FROM INT4_TBL WHERE f1 != ss.f1);