Исключение SQLServerException: недопустимое имя объекта

#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") Аннотация работает не так, как ожидалось.