java geometry mysql_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类型的数据。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中可以使用JTS(Java Topology Suite)库来解析MySQL中的Geometry数据类型。JTS是一个开源的Java库,用于处理空间数据,支持OGC(Open Geospatial Consortium)标准,提供了一系列构建和操作空间数据的工具。 要在Java中解析MySQL中的Geometry数据类型,可以通过以下步骤实现: 1. 首先,需要在Java项目中引入JTS库的依赖,例如使用Maven管理依赖的项目可以在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>com.vividsolutions</groupId> <artifactId>jts</artifactId> <version>1.13</version> </dependency> ``` 2. 在Java中读取MySQL中的Geometry数据类型,例如WKB格式的数据,可以使用JTS提供的WKBReader类,示例代码如下: ```java import com.vividsolutions.jts.geom.Geometry; import com.vividsolutions.jts.io.WKBReader; import java.sql.ResultSet; import java.sql.SQLException; public class GeometryParser { public Geometry parseGeometry(ResultSet resultSet, String columnName) throws SQLException { byte[] wkb = resultSet.getBytes(columnName); WKBReader reader = new WKBReader(); try { return reader.read(wkb); } catch (com.vividsolutions.jts.io.ParseException e) { throw new SQLException("Failed to parse geometry", e); } } } ``` 3. 解析完成后,可以使用JTS提供的Geometry类的方法来操作空间数据,例如获取几何对象的坐标,示例代码如下: ```java Geometry geometry = geometryParser.parseGeometry(resultSet, "geom"); Coordinate[] coordinates = geometry.getCoordinates(); ``` 通过以上步骤,就可以在Java中解析MySQL中的Geometry数据类型了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值