java程序操作Geometry對象


Geometry 空間地理對象,Oracle中存儲Geometry對象的字段類型是 MDSYS.SDO_GEOMETRY,在數據庫中構建Geometry對象的方法:

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.jar

讀取Geometry對象

在java映射的數據庫表實體類對象的字段中添加Geometry類型,如下:

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

這樣就能讀取到Geometry 對象,Geometry 有很多空間計算方法,具體可以查看源碼。

寫入Geometry對象

相對於讀取,寫入就相對麻煩一些,首先要構建一個Geometry對象,分點線面的構建:

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類型的數據。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM