![](/img/trans.png)
[英]Not able to execute remote stored procedure in MS SQL Server 2008 from Hibernate
[英]Hibernate execute Sql Server procedure
我嘗試了很多方法來將一個簡單的存儲過程稱為“休眠”,而不僅僅是找到一種方法。
我有一個返回本地表變量的過程:
SET NOCOUNT ON
declare @tableTemp Table
(
ID int,
Tipo nvarchar(50),
Regra nvarchar(50),
Quantidade int
)
select * from @tableTemp
我的查詢是:
Query query = em.createNativeQuery("{call GetEstatisticasDeRegras}");
List result = query.getResultList();
我不斷收到錯誤:
javax.persistence.PersistenceException: org.hibernate.MappingException: **No Dialect mapping for JDBC type: -9**
已經嘗試過:
*致電GetEstatisticasDeRegras
*執行GetEstatisticasDeRegras
*執行GetEstatisticasDeRegras
* {致電GetEstatisticasDeRegras}
*執行dbo.GetEstatisticasDeRegras
但是不是。 我的用戶擁有該過程的所有特權。
編輯
我的persistence.xml:
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0"
xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
<persistence-unit name="SIPAAM_WS_2">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<class>Model.DadosPreProcessamento.Evento</class>
<class>Model.DadosPreProcessamento.Servico</class>
<class>Model.DadosPreProcessamento.DadosPreProcessamento</class>
<class>Model.Jobs.Job</class>
<class>Model.Jobs.JobFiltro</class>
<class>Model.Jobs.JobResultado</class>
<class>Model.Jobs.JobResultadoDados</class>
<class>Model.Jobs.JobResultadoPontuacao</class>
<class>Model.Jobs.JobEstatisticas</class>
<class>Model.Usuario.Usuario</class>
<properties>
<property name="hibernate.connection.url"
value="jdbc:sqlserver://localhost;databaseName=SIPAAM;" />
<property name="hibernate.connection.username" value="x" />
<property name="hibernate.connection.password" value="x" />
<property name="hibernate.connection.driver_class" value="com.microsoft.sqlserver.jdbc.SQLServerDriver" />
<property name="hibernate.dialect" value="org.hibernate.dialect.SQLServerDialect" />
<property name="hibernate.show_sql" value="true" />
<property name="hibernate.hbm2ddl.auto" value="update" />
</properties>
</persistence-unit>
</persistence>
有什么幫助嗎?
發生此錯誤的原因是休眠狀態不知道如何將nvarchar
數據庫類型映射到Java類型。 您需要定義Dialect
。 假設您使用sqlserver2008,則可以這樣定義Dialect
public class MsSqlDialect extends SQLServer2008Dialect {
public MsSqlDialect(){
super();
registerHibernateType(Types.NVARCHAR, "string");
}
}
然后將hibernate.dialect
修改為您自己的
<property name="hibernate.dialect" value="xxx.xxxx.MsSqlDialect" />
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.