java程式操作Geometry對象

來源:互聯網
上載者:User

標籤:bsp   oracle   lines   工程   類對象   指定   class   jar包   工具包   

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類型的資料。

 

java程式操作Geometry對象

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.