ST_IsRing
定义
ST_IsRing 获取 ST_LineString,如果是环(如 ST_LineString 是闭合的简单线串),则返回 1 (Oracle) 或 t (PostgreSQL);否则返回 0 (Oracle) 或 f (PostgreSQL)。
语法
sde.st_isring (ln1 sde.st_geometry)
返回类型
布尔型
示例
创建一个包含单个 ST_LineString 列 ln1 的 ring_linestring 表。
CREATE TABLE ring_linestring (ln1 sde.st_geometry);
INSERT 语句将三个线串插入 ln1 列中。第一行包含一个不闭合不是环的线串。第二行包含一个闭合的简单线串(线串是环)。第三行包含一个闭合的非简单线串,因为线串与自己的内部相交。此线串也不是环。
Oracle
INSERT INTO RING_LINESTRING VALUES ( sde.st_linefromtext ('linestring (10.02 20.01, 10.32 23.98, 11.92 25.64)', 0) ); INSERT INTO RING_LINESTRING VALUES ( sde.st_linefromtext ('linestring (10.02 20.01, 11.92 35.64, 25.02 34.15, 19.15 33.94, 10.02 20.01)', 0) ); INSERT INTO RING_LINESTRING VALUES ( sde.st_linefromtext ('linestring (15.47 30.12, 20.73 22.12, 10.83 14.13, 16.45 17.24, 21.56 13.37, 11.23 22.56, 19.11 26.78, 15.47 30.12)', 0) );
PostgreSQL
INSERT INTO ring_linestring VALUES ( sde.st_linestring ('linestring (10.02 20.01, 10.32 23.98, 11.92 25.64)', 0) ); INSERT INTO ring_linestring VALUES ( sde.st_linestring ('linestring (10.02 20.01, 11.92 35.64, 25.02 34.15, 19.15 33.94, 10.02 20.01)', 0) ); INSERT INTO ring_linestring VALUES ( sde.st_linestring ('linestring (15.47 30.12, 20.73 22.12, 10.83 14.13, 16.45 17.24, 21.56 13.37, 11.23 22.56, 19.11 26.78, 15.47 30.12)', 0) );
查询将返回函数的结果。第一行返回 0,因为线串不是环;而第二行和第三行返回 1,因为线串是环。
Oracle
SELECT sde.st_isring (ln1) Is_it_a_ring FROM RING_LINESTRING; Is_it_a_ring 0 1 1
PostgreSQL
SELECT sde.st_isring (ln1) AS Is_it_a_ring FROM ring_linestring; Is_it_a_ring f t t
7/10/2012