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