#sql-server #spring-boot #hibernate #spring-data-jpa
#sql-сервер #весенняя загрузка #спящий режим #spring-data-jpa
Вопрос:
Я создал этот небольшой прототип с помощью Spring Boot, который отлично работает с базой данных Postgres, но мне пришлось изменить его на контейнер MSSQL, и теперь я получаю это исключение SQLServerException.
Это то, что у меня есть:
- Объект с именем StructuralElement
- таблица structural_element, и я вручную помещаю запись в эту таблицу.
- База данных представляет собой контейнер MSSQL с именем базы данных «master» и именем схемы «dbo».
- JpaRepository называется StructuralElementRepository
Я получаю исключение каждый раз .getAll()
, когда вызывается метод репозитория. Я не уверен, что происходит, но я предполагаю, что hibernate / jpa не может установить соединение с правильной таблицей?
Сценарий flyway
CREATE TABLE dbo.StructuralElement
(
id INT IDENTITY (1,1) NOT NULL,
name NVARCHAR(128) NULL,
description NVARCHAR(4000) NULL, -- could also be NTEXT
sequel INT NOT NULL, -- order within the Hierarchy
FK_parent INT NULL -- Hierarchy
);
Приложение.свойства
server.port=8080
# JPA / Hibernate
spring.jpa.show-sql=true
spring.jpa.hibernate.ddl-auto=none
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.SQLServer2012Dialect
spring.jpa.generate-ddl=false
#Database Connection
spring.datasource.driverClassName=com.microsoft.sqlserver.jdbc.SQLServerDriver
spring.datasource.url=jdbc:sqlserver://localhost:1433;database=master
spring.datasource.username=sa
spring.datasource.password=prototype_2020
spring.flyway.schemas=dbo
spring.flyway.locations=classpath:db/migration
spring.flyway.placeholders.schemaName: dbo
Сущность
@Data
@SuperBuilder
@Entity
@NoArgsConstructor
@AllArgsConstructor
@Table(name = "StructuralElement")
public class StructuralElement {
@Id
private Long id;
private String name;
private String description;
private Long sequel;
Репозиторий
@Repository
public interface PlanstellenRepository extends JpaRepository<Planstelle, Long> {
}
Это мой pom.xml
<?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.3.4.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.prototype</groupId>
<artifactId>userservice</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>userservice</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>15</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.flywaydb</groupId>
<artifactId>flyway-core</artifactId>
</dependency>
<dependency>
<groupId>com.microsoft.sqlserver</groupId>
<artifactId>mssql-jdbc</artifactId>
<scope>runtime</scope>
</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>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.modelmapper</groupId>
<artifactId>modelmapper</artifactId>
<version>2.3.8</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>15</source>
<target>15</target>
<release>15</release>
</configuration>
</plugin>
</plugins>
</build>
</project>
РЕДАКТИРОВАТЬ: изменен на правильный сценарий flyway.
Комментарии:
1. В вашем сценарии миграции вы называете свою таблицу
StructuralElement_Function
, но в определении сущности есть@Table
аннотация с именемStructuralElement
. Это намеренно?2. Вы не должны использовать основную базу данных для своих собственных таблиц и не должны использовать встроенную учетную запись sa.
3. @nkrivenko Извините, глупый я скопировал неправильную часть скрипта
4. @SMor Вы абсолютно правы, я изменю это, как только сопоставление заработает.
Ответ №1:
Я решил это, переименовав таблицу в structural_element
. @Table(name="StructuralElement")
Аннотация работает не так, как ожидалось.