首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法解析ST_GeomFromText类中的“serviceImpl”

无法解析ST_GeomFromText类中的“serviceImpl”
EN

Stack Overflow用户
提问于 2022-09-21 09:25:37
回答 1查看 115关注 0票数 2

无法在ST_GeomFromText类中解析“serviceImpl”。

我试图通过JPA将我的几何数据保存到mysql表中。

代码语言:javascript
复制
georepository.save("id", ST_GeomFromText('POLYGON((0 1, 2 5, 2 7, 0 7, 0 1))') ); 

但是我不能在ST_GeomFromText类中解析“serviceImpl”。

这是我的模型

代码语言:javascript
复制
public class Mygeo {

   @Id
   @Column(name = "id")
   private String id;

   @Column(name = "geodata", nullable = false)
   private Geometry geodata;
}

这就是我在DB中手动保存的方式。什么将是JPA的替代方式来保存这个。

代码语言:javascript
复制
INSERT INTO mygeo (id, geodata)VALUES ("ID",ST_GeomFromText('POLYGON((0 1, 2 5, 2 7, 0 7, 0 1))'));

注意:我确实可以访问这样的几何字符串

代码语言:javascript
复制
System.out.println(geometryObject.toString());
{"coordinates":[[[0,1],[2,5],[2,7],[0,7],[0,1]]],"type":"Polygon"}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-09-23 19:28:36

在使用Spring数据JPA时,如何将几何数据保存到数据库中,详细说明如下(一步一步):

我将在一个项目的帮助下解释。

项目结构:

MyGeo实体:

代码语言:javascript
复制
package com.solve.problemssolve;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;

import org.locationtech.jts.geom.Geometry;

import lombok.Data;

@Data
@Entity
public class MyGeo {

    @Id
    @Column(name = "id")
    private String id;

    @Column(name = "geodata", nullable = false)
    private Geometry geodata;
}

MyGeoRepository类

代码语言:javascript
复制
package com.solve.problemssolve;

import org.springframework.data.jpa.repository.JpaRepository;

public interface MyGeoRepository extends JpaRepository<MyGeo, String> {

}

application.properties:

代码语言:javascript
复制
spring.datasource.url=jdbc:mysql://localhost:3306/test
spring.datasource.username=root
spring.datasource.password=Anish@123
spring.jpa.hibernate.ddl-auto=update
spring.jpa.properties.hibernate.dialect=org.hibernate.spatial.dialect.mysql.MySQL5SpatialDialect

注意:您必须在春季引导应用程序中启用org.hibernate.spatial.dialect.mysql.MySQL5SpatialDialect以支持空间特性。

根据MySQL5SpatialDialect Hibernate文档的说法:

它是MySQL 5的方言,使用InnoDB引擎,支持其空间特性。

pom.xml:

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.7.4</version>
        <relativePath /> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.solve</groupId>
    <artifactId>problems-solve</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>problems-solve</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-configuration-processor</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-spatial</artifactId>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <excludes>
                        <exclude>
                            <groupId>org.projectlombok</groupId>
                            <artifactId>lombok</artifactId>
                        </exclude>
                    </excludes>
                </configuration>
            </plugin>
        </plugins>
    </build>

</project>

在MySQL DB (表结构)中:

注意:这个表是由Hibernate自动生成的,因为我保留了ddl-auto=update,但是您也可以手动创建表。

资源类别:

代码语言:javascript
复制
@RestController
public class Resource {

    @Autowired
    private MyGeoRepository myGeoRepository;
    
    @GetMapping("/save")
    public void save() throws ParseException {
        WKTReader wktReader = new WKTReader();
        Geometry geometry = wktReader.read("POLYGON((0 1, 2 5, 2 7, 0 7, 0 1))");
        System.out.println(geometry);
        MyGeo geo = new MyGeo();
        geo.setGeodata(geometry);
        geo.setId("ID");
        myGeoRepository.save(geo); 
        System.out.println(myGeoRepository.findById("ID"));
    }
        
}

您必须使用WKTReader通过JPA保存数据。

根据WKTReader文档:

将众所周知的文本格式的几何转换为几何学. WKTReader支持从读取器或字符串中提取几何对象。这允许它作为解析器从嵌入到其他数据格式(例如XML)的文本块中读取几何对象。 WKTReader由GeometryFactory参数化,以允许它创建相应实现的几何对象。特别是,GeometryFactory确定所使用的PrecisionModel和SRID。 WKTReader将所有输入数字转换为精确的内部表示形式。

根据WKTReader.read(字符串wellKnownText)文档:

它从字符串中读取众所周知的几何文本表示.

此SQL语句ST_GeomFromText('POLYGON((0 1, 2 5, 2 7, 0 7, 0 1))')等效于此行Geometry geometry = wktReader.read("POLYGON((0 1, 2 5, 2 7, 0 7, 0 1))");

只要我已经运行了这个例子,它就成功地保存了下来,没有任何问题。

服务器日志截图:

DB行截图:

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73798390

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档