gpt4 book ai didi

java - JTS 中的地理数据类型

转载 作者:太空宇宙 更新时间:2023-11-04 12:59:18 27 4
gpt4 key购买 nike

我最近发现在处理项目中的地理类型时使用 JTS 库的潜力。我使用 hibernate 作为我的 ORM(包括 hibernate 空间)。

在知道 JTS 的存在之前,我将坐标存储在一个名为 LatLon 的自定义类中;每当我想管理多段线时,我都会创建它们的列表,例如列表。我意识到在数据库中进行 CRUD 操作时的性能有多糟糕。

所以,正如我之前告诉过你的,我发现我的 LatLon 类可以被 JTS 的 Point 类取代。我开始实现它并替换 LatLon 属性,但我有几个问题:

  1. 我使用 XML(而不是注释)映射我的类。以下说法正确的是?

    (Java 类)

    ...
    private Point puntoInicio;
    ...

    (XML 映射)

    <property name="puntoInicio" type="org.hibernate.spatial.GeometryType" column="RUTA_PUNTOINICIO" not-null="true" />

  2. 如何存储折线?我没有找到任何名为 Polyline 的数据类型。不过,我发现了其他类似 LineString 的东西。我可以用它来表示折线吗?我如何映射它们?

非常感谢!

编辑:我正在使用 Hibernate 5.0.7.Final + Hibernate Spatial 5.0.7.Final

编辑2:很抱歉我的延迟并且不接受任何答案。我前段时间撤销了整个修改,但我想这样修改和实现。感谢您的时间和耐心。

最佳答案

我已经能够在不指定列类型并将 Hibernate 和 Hibernate Spatial 更新为 5 的情况下使其工作。这样,数据就会存储为二进制。现在问题来了,我有一个名为“Conductor”的类,当从数据库检索数据时,Hibernate 会抛出异常:

    Error Exception: could not deserialize
org.hibernate.type.SerializationException: could not deserialize
at org.hibernate.internal.util.SerializationHelper.doDeserialize(SerializationHelper.java:243)
at org.hibernate.internal.util.SerializationHelper.deserialize(SerializationHelper.java:287)
at org.hibernate.type.descriptor.java.SerializableTypeDescriptor.fromBytes(SerializableTypeDescriptor.java:138)
at org.hibernate.type.descriptor.java.SerializableTypeDescriptor.wrap(SerializableTypeDescriptor.java:113)
at org.hibernate.type.descriptor.java.SerializableTypeDescriptor.wrap(SerializableTypeDescriptor.java:27)
at org.hibernate.type.descriptor.sql.VarbinaryTypeDescriptor$2.doExtract(VarbinaryTypeDescriptor.java:53)
at org.hibernate.type.descriptor.sql.BasicExtractor.extract(BasicExtractor.java:47)
at org.hibernate.type.AbstractStandardBasicType.nullSafeGet(AbstractStandardBasicType.java:238)
at org.hibernate.type.AbstractStandardBasicType.nullSafeGet(AbstractStandardBasicType.java:234)
at org.hibernate.type.AbstractStandardBasicType.nullSafeGet(AbstractStandardBasicType.java:224)
at org.hibernate.type.AbstractStandardBasicType.hydrate(AbstractStandardBasicType.java:300)
at org.hibernate.persister.entity.AbstractEntityPersister.hydrate(AbstractEntityPersister.java:2727)
at org.hibernate.loader.Loader.loadFromResultSet(Loader.java:1728)
at org.hibernate.loader.Loader.instanceNotYetLoaded(Loader.java:1654)
at org.hibernate.loader.Loader.getRow(Loader.java:1543)
at org.hibernate.loader.Loader.getRowFromResultSet(Loader.java:727)
at org.hibernate.loader.Loader.processResultSet(Loader.java:972)
at org.hibernate.loader.Loader.doQuery(Loader.java:930)
at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:336)
at org.hibernate.loader.Loader.doList(Loader.java:2611)
at org.hibernate.loader.Loader.doList(Loader.java:2594)
at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2423)
at org.hibernate.loader.Loader.list(Loader.java:2418)
at org.hibernate.loader.hql.QueryLoader.list(QueryLoader.java:501)
at org.hibernate.hql.internal.ast.QueryTranslatorImpl.list(QueryTranslatorImpl.java:371)
at org.hibernate.engine.query.spi.HQLQueryPlan.performList(HQLQueryPlan.java:216)
at org.hibernate.internal.SessionImpl.list(SessionImpl.java:1326)
at org.hibernate.internal.QueryImpl.list(QueryImpl.java:87)
...
//stuff from my webapp
...
Caused by: java.io.StreamCorruptedException: invalid stream header: 01303130
at java.io.ObjectInputStream.readStreamHeader(Unknown Source)
at java.io.ObjectInputStream.<init>(Unknown Source)
at org.hibernate.internal.util.SerializationHelper$CustomObjectInputStream.<init>(SerializationHelper.java:309)
at org.hibernate.internal.util.SerializationHelper$CustomObjectInputStream.<init>(SerializationHelper.java:299)
at org.hibernate.internal.util.SerializationHelper.doDeserialize(SerializationHelper.java:218)
... 85 more

关于java - JTS 中的地理数据类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35056886/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com