java程序操做Geometry对象

Geometry 空间地理对象,Oracle中存储Geometry对象的字段类型是 MDSYS.SDO_GEOMETRY,在数据库中构建Geometry对象的方法:java

v_pointarray  MDSYS.sdo_ordinate_array;
MDSYS.SDO_GEOMETRY(2003,
                 20131028,
                 null,
                 MDSYS.SDO_ELEM_INFO_ARRAY(1, 1003, 1),
                 v_pointarray);

其中 20131028是空间参考系。数据库

在java程序中如何读写带有Geometry对象的表呢,经常使用的geotools工具包。在maven工程中引用jar包jts-1.13.jarmaven

读取Geometry对象工具

在java映射的数据库表实体类对象的字段中添加Geometry类型,以下:spa

@Column(name = "GEOM")
private Geometry geom;code

这样就能读取到Geometry 对象,Geometry 有不少空间计算方法,具体能够查看源码。对象

写入Geometry对象blog

相对于读取,写入就相对麻烦一些,首先要构建一个Geometry对象,分点线面的构建:get

private GeometryFactory geometryFactory = JTSFactoryFinder.getGeometryFactory(null);源码

点的构建

Envelope e = new Envelope(new Coordinate(x, y));

线的构建

LineString line = geometryFactory.createLineString(Coordinate[]);

line.setSRID(20131028);
rb.setGeometry(line);

其中,rb实体类对象的Geometry的定义格式以下:

@Column(name = "PKG_CONVEX", jdbcType = JdbcType.STRUCT)
private Geometry geometry;

必定要指定jdbcType 类型,Oracle数据库中Geometry对象只接收STRUCT类型的数据。

相关文章
相关标签/搜索