SQL Server 2012/2018 - неверное имя объекта - PullRequest
0 голосов
/ 10 июля 2019

Я занимаюсь разработкой приложения, которое обращается к базе данных под управлением SQL Server 2012 через среду Hibernate.Однако я не могу понять, как использовать мою последовательность для генерации идентификатора новой записи для добавления;Я получаю исключение всякий раз, когда пытаюсь сохранить новый экземпляр объекта в моей таблице базы данных.Класс для сохранения:

package com.xantrix.webapp.entities;

import java.io.Serializable;
import java.util.Date;

import javax.persistence.Basic;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.SequenceGenerator;
import javax.persistence.Table;
import javax.persistence.TableGenerator;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;

@Entity
@Table(name = "Coupons")
public class Coupons implements Serializable
{
    private static final long serialVersionUID = -2788720560904709897L;

    @Id
    //@GeneratedValue(strategy=GenerationType.TABLE)
    /*
    @TableGenerator(
        name="Coupons",
        table="Progressivi",
        pkColumnName="Tipo",
        valueColumnName="Progressivo",
        allocationSize=200
        )
        */
    @SequenceGenerator(name="Coup_Gen", sequenceName="Test_Seq")
    @GeneratedValue(generator="Coup_Gen")
    //@GeneratedValue(generator="Coupons")
    @Column(name = "Id")
    private long id;

    @Temporal(TemporalType.TIME)
    @Column(name = "Data")
    private Date dataCreaz;

    @Basic
    private int idDeposito;

    @Basic
    private int qta;

    @Basic
    private double valore;

    @ManyToOne
    @JoinColumn(name = "IdCliente", referencedColumnName = "CODFIDELITY")
    private Clienti cliente;

    public Coupons()
    {

    }

    public long getId() {
        return id;
    }

    public void setId(long id) {
        this.id = id;
    }

    public Date getDataCreaz() {
        return dataCreaz;
    }

    public void setDataCreaz(Date dataCreaz) {
        this.dataCreaz = dataCreaz;
    }

    public int getIdDeposito() {
        return idDeposito;
    }

    public void setIdDeposito(int idDeposito) {
        this.idDeposito = idDeposito;
    }

    public int getQta() {
        return qta;
    }

    public void setQta(int qta) {
        this.qta = qta;
    }

    public double getValore() {
        return valore;
    }

    public void setValore(double valore) {
        this.valore = valore;
    }

    public Clienti getCliente() {
        return cliente;
    }

    public void setCliente(Clienti cliente) {
        this.cliente = cliente;
    }
}

Как изменить SQL-запрос, который Hibernate использует для запроса последовательности Microsoft SQL Server с помощью веб-приложения Spring MVC 5?

Iне может использовать все последовательности Microsoft SQL Server с Hibernate веб-приложения Spring MVC 5 из-за ошибки

Invalid object name <sequence>.

Эта проблема касается Microsoft SQL Server 2012 (но также и Microsoft SQL Server 2018).

Я использую среду Spring MVC 5 с Hibernate в Spring Tool Suite 4. Сервер Apache Tomcat 9.0.19.

Я создал пользователя с именем

WebClient1

в SQLStudio Management Server (Microsoft SQL Server 2012).

Я создал следующую последовательность:

USE [AlphaShop]
GO

USE [AlphaShop]
GO

/****** Object:  Sequence [dbo].[Test_Seq]    Script Date: 09/07/2019 10:56:28 ******/
CREATE SEQUENCE [dbo].[Test_Seq] 
 AS [bigint]
 START WITH 500
 INCREMENT BY 50
 MINVALUE 500
 MAXVALUE 9223372036854775807
 CACHE 
GO

Следующий запрос SQL успешно работает в Microsoft SQL Server Management Studio:

SELECT NEXT VALUE FOR dbo.Test_Seq;

, но если я пытаюсь найти следующий URL-адрес веб-приложения, появляется ошибка HTTP Status 500: http://localhost:8080/alphashop/coupons/aggiungi/67000023, где текст «67000023» - это идентификатор существующего пользователя, как показанорезультаты следующего SQL-запроса:

select * from CLIENTI
where CODFIDELITY = 67000023

В консоли Spring Tool Suite 4 я вижу последний вызванный SQL-запрос:

Hibernate: 
    select
        next_val as id_val 
    from
        Test_Seq with (updlock,
        rowlock)
lug 10, 2019 12:26:38 PM org.hibernate.id.enhanced.TableStructure$1$1 execute
ERROR: could not read a hi value
com.microsoft.sqlserver.jdbc.SQLServerException: Il nome di oggetto 'Test_Seq' non è valido.
    at com.microsoft.sqlserver.jdbc.SQLServerException.makeFromDatabaseError(SQLServerException.java:256)
    at com.microsoft.sqlserver.jdbc.SQLServerStatement.getNextResult(SQLServerStatement.java:1621)

lug 10, 2019 12:26:38 PM org.hibernate.engine.jdbc.spi.SqlExceptionHelper logExceptions
WARN: SQL Error: 208, SQLState: S0002
lug 10, 2019 12:26:38 PM org.hibernate.engine.jdbc.spi.SqlExceptionHelper logExceptions
ERROR: Il nome di oggetto 'Test_Seq' non è valido.
lug 10, 2019 12:26:38 PM org.apache.catalina.core.StandardWrapperValve invoke
GRAVE: Servlet.service() for servlet [dispatcher] in context with path [/alphashop] threw exception [Request processing failed; nested exception is javax.persistence.PersistenceException: org.hibernate.exception.SQLGrammarException: error performing isolated work] with root cause
com.microsoft.sqlserver.jdbc.SQLServerException: Il nome di oggetto 'Test_Seq' non è valido.
    at com.microsoft.sqlserver.jdbc.SQLServerException.makeFromDatabaseError(SQLServerException.java:256)
    at com.microsoft.sqlserver.jdbc.SQLServerStatement.getNextResult(SQLServerStatement.java:1621)

Как видите, Hibernate генерируетнеправильный SQL-запрос

    select
        next_val as id_val 
    from
        Test_Seq with (updlock,
        rowlock)

вместо:

SELECT NEXT VALUE FOR dbo.Test_Seq;

, который работает успешно.

Ошибка HTTP Status 500, отображаемая на HTML-странице Apache Tomcat 9через веб-браузер Mozilla Firefox 68.0, это:

Type Exception Report
Message Request processing failed; nested exception is javax.persistence.PersistenceException: org.hibernate.exception.SQLGrammarException: error performing isolated work
Description The server encountered an unexpected condition that prevented it from fulfilling the request.
Exception
org.springframework.web.util.NestedServletException: Request processing failed; nested exception is javax.persistence.PersistenceException: org.hibernate.exception.SQLGrammarException: error performing isolated work
    org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1013)
Root Cause
javax.persistence.PersistenceException: org.hibernate.exception.SQLGrammarException: error performing isolated work
    org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:154)
    org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:181)
Root Cause
org.hibernate.exception.SQLGrammarException: error performing isolated work
    org.hibernate.exception.internal.SQLStateConversionDelegate.convert(SQLStateConversionDelegate.java:106)
    org.hibernate.exception.internal.StandardSQLExceptionConverter.convert(StandardSQLExceptionConverter.java:42)
Root Cause
com.microsoft.sqlserver.jdbc.SQLServerException: Il nome di oggetto 'Test_Seq' non è valido.
    com.microsoft.sqlserver.jdbc.SQLServerException.makeFromDatabaseError(SQLServerException.java:256)
    com.microsoft.sqlserver.jdbc.SQLServerStatement.getNextResult(SQLServerStatement.java:1621)

В проводнике объектов я вижу последовательность "dbo.Test_Seq".Имя базы данных - AlphaShop.

Я попытался выполнить следующую команду SQL, но это не решило проблему:

ALTER LOGIN WebClient1 WITH DEFAULT_DATABASE = [AlphaShop];

Тип аутентификации пользователя - «Аутентификация».SQL Server ".У пользователя есть роль "public".

Я не могу понять, как использовать мою последовательность для генерации идентификатора новой записи для добавления;Я получаю исключение, когда пытаюсь сохранить новый экземпляр объекта в моей таблице базы данных.

Пожалуйста, помогите.Спасибо заранее.ОС: Microsoft Windows 10 64-битная версия 2019.3

1 Ответ

0 голосов
/ 10 июля 2019

Я нашел решение: вам нужно изменить свойства Hibernate в вашем файле "application.properties", чтобы указать правильный диалект (в моем случае правильный диалект "SQLServer2012Dialect"):

#Hibernate properties
hibernate.dialect = org.hibernate.dialect.SQLServer2012Dialect
hibernate.show_sql = true
hibernate.format_sql = true
hibernate.hbm2ddl.auto = validate

вместо неправильного

#Hibernate properties
hibernate.dialect =  org.hibernate.dialect.SQLServerDialect
hibernate.show_sql = true
hibernate.format_sql = true
hibernate.hbm2ddl.auto = validate
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...