1. 背景
1.1. SDO_GEOMETRY的应用场景及能力
在数字化城市、物联网和新能源汽车等领域蓬勃发展的背景下,空间数据类型的存储和分析需求日益增长;对于涉及位置信息服务和地理位置信息应用而言,数据库中具备对sdo_geometry数据类型的支持无疑将更好地支撑空间数据的存取与分析过程。
空间数据对象是一组直线相连的点的序列而组成,通过sdo_geometry数据类型可以描述OGC(OpenGIS Consortium)定义的7种空间对象类型(point \ linestring \ polygon \ multipoint \ multilinestring \ multipolygon \ collection),这7种空间类型可以覆盖大部分实际应用场景。
空间数据对象之间支持进行关系运算,如包含、相交等,空间关系运算是cpu密集型的运算,在大数据量场景下常规的需要空间索引来提供快速空间关系查询的能力。
1.2. OceanBase v4.2.2release SDO_GEOMETRY特性支持
oceanbase 4.2.2版本下Oracle模式下sdo_geometry类型支持如下特性
特性1 : sdo_geometry支持
用户可以定义数据类型为sdo_geometry,支持PL/SQL下操作sdo_geometry数据类型。
特性2: sdo_geometry成员函数
- 构造函数:支持通过默认构造函数、Well-Known-Binary数据格式以及Well-Known-Text数据格式创建sdo_geometry数据类型;
- 查询:支持通过成员函数get_dims/get_gtype/st_isvalid来查询sdo_geometry空间对象的维度、类型以及是否是有效的空间对象的信息;
- 格式转换:支持通过成员函数get_wkb/get_wkt/get_geojson来将sdo_geometry转换为Well-Known-Binary数据格式、Well-Known-Text数据格式以及json数据格式
特性3: sdo_geometry类型存储
支持定义表中字段为sdo_geometry类型,sdo_geometry数据类型会将其基础属性拆分成多个内置类型的隐藏列进行存储,有效提高存储效率。
特性4: sdo_geometry属性访问
sdo_geometry做为复杂数据类型,包含多个内在属性,支持在SQL/PL下访问其属性。
2. 使用操作
2.1 ddl/dml/select
# ddl,创建gis类型字段
CREATE TABLE cola_markets (
mkt_id NUMBER PRIMARY KEY,
name VARCHAR2(32),
shape SDO_GEOMETRY); --SDO_GEOMETRY表示gis类型
# 插入gis类型数据:通过sdo_geometry constructor创建gis对象实例,
INSERT INTO cola_markets VALUES(
1,
'cola_a',
SDO_GEOMETRY( --创建gis对象
2003, -- 表示2维的polygon
NULL, -- 未定义srid
NULL, -- 该字段仅对point对象有意义
SDO_ELEM_INFO_ARRAY(1,1003,1), -- 1表示从SDO_ORDINATE_ARRAY第一个成员开始,
-- 1003表示是一个多边形外环,1表示直线连接
SDO_ORDINATE_ARRAY(10,105, 15,105, 20,110, 10,110, 10,105) -- 该多边形顶点的坐标值
)
);
# 查询gis字段,默认按sdo_geometry constructor格式输出
select shape from cola_markets;
SHAPE(SDO_GTYPE,