point.sql

来自「postgresql8.3.4源码,开源数据库」· SQL 代码 · 共 77 行

SQL
77
字号
---- POINT--CREATE TABLE POINT_TBL(f1 point);INSERT INTO POINT_TBL(f1) VALUES ('(0.0,0.0)');INSERT INTO POINT_TBL(f1) VALUES ('(-10.0,0.0)');INSERT INTO POINT_TBL(f1) VALUES ('(-3.0,4.0)');INSERT INTO POINT_TBL(f1) VALUES ('(5.1, 34.5)');INSERT INTO POINT_TBL(f1) VALUES ('(-5.0,-12.0)');-- bad format points INSERT INTO POINT_TBL(f1) VALUES ('asdfasdf');INSERT INTO POINT_TBL(f1) VALUES ('10.0,10.0');INSERT INTO POINT_TBL(f1) VALUES ('(10.0 10.0)');INSERT INTO POINT_TBL(f1) VALUES ('(10.0,10.0');SELECT '' AS six, * FROM POINT_TBL;-- left of SELECT '' AS three, p.* FROM POINT_TBL p WHERE p.f1 << '(0.0, 0.0)';-- right of SELECT '' AS three, p.* FROM POINT_TBL p WHERE '(0.0,0.0)' >> p.f1;-- above SELECT '' AS one, p.* FROM POINT_TBL p WHERE '(0.0,0.0)' >^ p.f1;-- below SELECT '' AS one, p.* FROM POINT_TBL p WHERE p.f1 <^ '(0.0, 0.0)';-- equal SELECT '' AS one, p.* FROM POINT_TBL p WHERE p.f1 ~= '(5.1, 34.5)';-- point in box SELECT '' AS three, p.* FROM POINT_TBL p   WHERE p.f1 <@ box '(0,0,100,100)';SELECT '' AS three, p.* FROM POINT_TBL p   WHERE not p.f1 <@ box '(0,0,100,100)';SELECT '' AS two, p.* FROM POINT_TBL p   WHERE p.f1 <@ path '[(0,0),(-10,0),(-10,10)]';SELECT '' AS six, p.f1, p.f1 <-> point '(0,0)' AS dist   FROM POINT_TBL p   ORDER BY dist;SELECT '' AS thirtysix, p1.f1 AS point1, p2.f1 AS point2, p1.f1 <-> p2.f1 AS dist   FROM POINT_TBL p1, POINT_TBL p2   ORDER BY dist, p1.f1[0], p2.f1[0];SELECT '' AS thirty, p1.f1 AS point1, p2.f1 AS point2   FROM POINT_TBL p1, POINT_TBL p2   WHERE (p1.f1 <-> p2.f1) > 3;-- put distance result into output to allow sorting with GEQ optimizer - tgl 97/05/10SELECT '' AS fifteen, p1.f1 AS point1, p2.f1 AS point2, (p1.f1 <-> p2.f1) AS distance   FROM POINT_TBL p1, POINT_TBL p2   WHERE (p1.f1 <-> p2.f1) > 3 and p1.f1 << p2.f1   ORDER BY distance, p1.f1[0], p2.f1[0];-- put distance result into output to allow sorting with GEQ optimizer - tgl 97/05/10SELECT '' AS three, p1.f1 AS point1, p2.f1 AS point2, (p1.f1 <-> p2.f1) AS distance   FROM POINT_TBL p1, POINT_TBL p2    WHERE (p1.f1 <-> p2.f1) > 3 and p1.f1 << p2.f1 and p1.f1 >^ p2.f1   ORDER BY distance;

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?