- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对将 Spring 与空间数据一起使用还很陌生,我正在尝试开发一个示例,该示例利用 Spring 的嵌入式 H2 数据库与空间数据。我有我的实体类,并试图提出一个集成类来测试我的服务功能。不幸的是,我不断收到我不明白的错误消息。如有帮助,将不胜感激
package com.whot.domain;
import javax.persistence.*;
import java.io.Serializable;
@Entity
public class Address implements WhotEntity{
@Id
@SequenceGenerator(name="addressIdSeq", sequenceName = "address_id_seq")
@GeneratedValue(strategy= GenerationType.AUTO, generator = "addressIdSeq")
private Long id;
@Column(name="street_name")
private String streetName;
private Long unit;
@Column(name = "street_number")
private Long number;
public Address(String streetName, Long unit, Long number) {
this.streetName = streetName;
this.unit = unit;
this.number = number;
}
public Address(String streetName, Long number){
this(streetName, -1L, number);
}
public Address(){
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getStreetName() {
return streetName;
}
public void setStreetName(String streetName) {
this.streetName = streetName;
}
public Long getUnit() {
return unit;
}
public void setUnit(Long unit) {
this.unit = unit;
}
public Long getNumber() {
return number;
}
public void setNumber(Long number) {
this.number = number;
}
public String toString(){
return String.format("%s[id: %d]", getClass().getName(), id);
}
}
和其他类 Hotspot
package com.whot.domain;
import org.springframework.data.geo.Point;
import javax.persistence.*;
@Entity
public class Hotspot implements WhotEntity{
@Id
@SequenceGenerator(name="hotspotIdSeq", sequenceName = "hotspot_id_seq")
@GeneratedValue(strategy= GenerationType.AUTO, generator = "hotspotIdSeq")
private Long id;
private String name;
@OneToOne
@JoinColumn(name = "ADDR_ID")
private Address address;
@Column(columnDefinition = "geometry(Point, 4326)")
private Point location;
public Hotspot(String name, Address address, Point location) {
this.name = name;
this.address = address;
this.location = location;
}
public Hotspot() {
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Address getAddress() {
return address;
}
public void setAddress(Address address) {
this.address = address;
}
public Point getLocation() {
return location;
}
public void setLocation(Point location) {
this.location = location;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (!(o instanceof Hotspot)) return false;
Hotspot hotspot = (Hotspot) o;
if (getId() != null ? !getId().equals(hotspot.getId()) : hotspot.getId() != null) return false;
if (getName() != null ? !getName().equals(hotspot.getName()) : hotspot.getName() != null) return false;
if (getAddress() != null ? !getAddress().equals(hotspot.getAddress()) : hotspot.getAddress() != null)
return false;
return getLocation() != null ? getLocation().equals(hotspot.getLocation()) : hotspot.getLocation() == null;
}
@Override
public int hashCode() {
int result = getId() != null ? getId().hashCode() : 0;
result = 31 * result + (getName() != null ? getName().hashCode() : 0);
result = 31 * result + (getLocation() != null ? getLocation().hashCode() : 0);
return result;
}
public String toString(){
return String.format("%s[id: %d]", getClass().getName(), id);
}
}
我有我的集成测试类,我正在尝试设置它,并且我有这个
package com.whot.dao;
import com.whot.domain.Address;
import com.whot.domain.Hotspot;
import com.whot.repository.AddressRepository;
import com.whot.repository.HotspotRespository;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.orm.jpa.DataJpaTest;
import org.springframework.boot.test.autoconfigure.orm.jpa.TestEntityManager;
import org.springframework.data.geo.Point;
import org.springframework.test.context.ActiveProfiles;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.transaction.annotation.Transactional;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;
/**
* Created by Bart on 2017-01-07.
*/
@RunWith(SpringJUnit4ClassRunner.class)
@ActiveProfiles("test")
@DataJpaTest
@Transactional
public class HotspotRepositoryTest {
@Autowired
private HotspotRespository hotspotRepo;
@Autowired
private AddressRepository addressRepo;
@Autowired
private TestEntityManager em;
private HashSet<String> hotspotSet;
@Before
public void setUp(){
hotspotSet = new HashSet<>();
addressRepo.save(new Address("Ossiomo Street", -1L, 2L));
addressRepo.save(new Address("Wilson Avenue", 103L, 2025L));
addressRepo.save(new Address("Rue Clark", 303L, 2084L));
addressRepo.save(new Address("Plateau Close", 20L, 40L));
}
@Test
public void TestFindAllHotspots(){
// some test code here
}
}
这是我得到的异常的堆栈跟踪。
Caused by: org.h2.jdbc.JdbcSQLException: Syntax error in SQL statement "CREATE TABLE HOTSPOT (ID BIGINT GENERATED BY DEFAULT AS IDENTITY, LOCATION GEOMETRY(POINT[*], 4326), NAME VARCHAR(255), ADDR_ID BIGINT, PRIMARY KEY (ID)) "; expected "long"; SQL statement:
create table hotspot (id bigint generated by default as identity, location geometry(Point, 4326), name varchar(255), addr_id bigint, primary key (id)) [42001-193]
at org.h2.message.DbException.getJdbcSQLException(DbException.java:345) ~[h2-1.4.193.jar:1.4.193]
at org.h2.message.DbException.getSyntaxError(DbException.java:205) ~[h2-1.4.193.jar:1.4.193]
at org.h2.command.Parser.readLong(Parser.java:3094) ~[h2-1.4.193.jar:1.4.193]
at org.h2.command.Parser.parseColumnWithType(Parser.java:4099) ~[h2-1.4.193.jar:1.4.193]
at org.h2.command.Parser.parseColumnForTable(Parser.java:3938) ~[h2-1.4.193.jar:1.4.193]
at org.h2.command.Parser.parseCreateTable(Parser.java:5977) ~[h2-1.4.193.jar:1.4.193]
at org.h2.command.Parser.parseCreate(Parser.java:4238) ~[h2-1.4.193.jar:1.4.193]
at org.h2.command.Parser.parsePrepared(Parser.java:362) ~[h2-1.4.193.jar:1.4.193]
at org.h2.command.Parser.parse(Parser.java:317) ~[h2-1.4.193.jar:1.4.193]
at org.h2.command.Parser.parse(Parser.java:289) ~[h2-1.4.193.jar:1.4.193]
at org.h2.command.Parser.prepareCommand(Parser.java:254) ~[h2-1.4.193.jar:1.4.193]
at org.h2.engine.Session.prepareLocal(Session.java:561) ~[h2-1.4.193.jar:1.4.193]
at org.h2.engine.Session.prepareCommand(Session.java:502) ~[h2-1.4.193.jar:1.4.193]
at org.h2.jdbc.JdbcConnection.prepareCommand(JdbcConnection.java:1203) ~[h2-1.4.193.jar:1.4.193]
at org.h2.jdbc.JdbcStatement.executeInternal(JdbcStatement.java:170) ~[h2-1.4.193.jar:1.4.193]
at org.h2.jdbc.JdbcStatement.execute(JdbcStatement.java:158) ~[h2-1.4.193.jar:1.4.193]
at org.hibernate.tool.schema.internal.exec.GenerationTargetToDatabase.accept(GenerationTargetToDatabase.java:54) ~[hibernate-core-5.2.5.Final.jar:5.2.5.Final]
最佳答案
LOCATION GEOMETRY(POINT[*], 4326)
不是有效的 H2 数据库列声明。正确的声明是LOCATION GEOMETRY
。如果将 Hotspot
类中 location
字段的声明修改为 @Column(columnDefinition = "GEOMETRY")
,则您的表应该会创建很好。
还值得注意的是H2 does not have in-built support对于空间数据类型。您将要求应用程序类路径上的 JTS 拓扑套件能够使用空间列,如链接文档中所述。
关于java - 嵌入式 h2 数据库未运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41669417/
我的问题是如何在 python 中创建一个简单的数据库。我的例子是: User = { 'Name' : {'Firstname', 'Lastname'}, 'Address' : {'Street
我需要创建一个与远程数据库链接的应用程序! mysql 是最好的解决方案吗? Sqlite 是唯一的本地解决方案吗? 我使用下面的方法,我想知道它是否是最好的方法! NSString *evento
给定两台 MySQL 服务器,一台本地,一台远程。两者都有一个包含表 bohica 的数据库 foobar。本地服务器定义了用户 'myadmin'@'%' 和 'myadmin'@'localhos
我有以下灵活的搜索查询 Select {vt:code},{vt:productcode},{vw:code},{vw:productcode} from {abcd AS vt JOIN wxyz
好吧,我的电脑开始运行有点缓慢,所以我重置了 Windows,保留了我的文件。因为我的大脑还没有打开,所以我忘记事先备份我的 MySQL 数据库。我仍然拥有所有原始文件,因此我实际上仍然拥有数据库,但
如何将我的 Access 数据库 (.accdb) 转换为 SQLite 数据库 (.sqlite)? 请,任何帮助将不胜感激。 最佳答案 1)如果要转换 db 的结构,则应使用任何 DB 建模工具:
系统检查发现了一些问题: 警告:?:(mysql.W002)未为数据库连接“默认”设置 MySQL 严格模式 提示:MySQL 的严格模式通过将警告升级为错误来修复 MySQL 中的许多数据完整性问题
系统检查发现了一些问题: 警告:?:(mysql.W002)未为数据库连接“默认”设置 MySQL 严格模式 提示:MySQL 的严格模式通过将警告升级为错误来修复 MySQL 中的许多数据完整性问题
我想在相同的 phonegap 应用程序中使用 android 数据库。 更多说明: 我创建了 phonegap 应用程序,但 phonegap 应用程序不支持服务,所以我们已经在 java 中为 a
Time Tracker function clock() { var mytime = new Date(); var seconds
我需要在现有项目上实现一些事件的显示。我无法更改数据库结构。 在我的 Controller 中,我(从 ajax 请求)传递了一个时间戳,并且我需要显示之前的 8 个事件。因此,如果时间戳是(转换后)
我有一个可以收集和显示各种测量值的产品(不会详细介绍)。正如人们所期望的那样,显示部分是一个数据库+建立在其之上的网站(使用 Symfony)。 但是,我们可能还会创建一个 API 来向第三方公开数据
我们将 SQL Server 从 Azure VM 迁移到 Azure SQL 数据库。 Azure VM 为 DS2_V2、2 核、7GB RAM、最大 6400 IOPS Azure SQL 数据
我正在开发一个使用 MongoDB 数据库的程序,但我想问在通过 Java 执行 SQL 时是否可以使用内部数据库进行测试,例如 H2? 最佳答案 你可以尝试使用Testcontainers Test
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 已关闭 9 年前。 此问题似乎与 a specific programming problem, a sof
我正在尝试使用 MSI 身份验证(无需用户名和密码)从 Azure 机器学习服务连接 Azure SQL 数据库。 我正在尝试在 Azure 机器学习服务上建立机器学习模型,目的是我需要数据,这就是我
我在我的 MySQL 数据库中使用这个查询来查找 my_column 不为空的所有行: SELECT * FROM my_table WHERE my_column != ""; 不幸的是,许多行在
我有那个基地:http://sqlfiddle.com/#!2/e5a24/2这是 WordPress 默认模式的简写。我已经删除了该示例不需要的字段。 如您所见,我的结果是“类别 1”的两倍。我喜欢
我有一张这样的 table : mysql> select * from users; +--------+----------+------------+-----------+ | userid
我有表: CREATE TABLE IF NOT EXISTS `category` ( `id` int(11) NOT NULL, `name` varchar(255) NOT NULL
我是一名优秀的程序员,十分优秀!