0
derzeit verwende ich Hibernate mit MS SQL 2008 in meinem Projekt. Ich versuche Stored Procedure in Hibernate auszuführen. unten ist die SP:Hibernate mit MS SQL gespeicherte Prozedur
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER PROCEDURE [dbo].[GetUserDetails] (@userId int)
AS
BEGIN
SELECT * FROM dcf_user_m WHERE nuserid = @userId;
END
Exec dbo.GetUserDetails @userId=14
Unten ist der Hibernate-Code zur Ausführung.
Session session = transactionManager.getSessionFactory().getCurrentSession();
Transaction transaction = session.getTransaction();
if(!transaction.isActive()){
session.beginTransaction();
}
Query query = session.createSQLQuery("Exec dbo.GetUserDetails @userId=:userId").setParameter("userId", 14);
List result = query.list();
for(int i=0; i<result.size(); i++){
com.majesco.msig.entity.UserInfo user = (com.majesco.msig.entity.UserInfo)result.get(i);
System.out.println(user.getUsername());
}
auf query.list() Ich bekomme unter Fehler.
INFO: Reloading Context with name [/msig] is completed
Hibernate: Exec dbo.GetUserDetails @userId=?
org.hibernate.MappingException: No Dialect mapping for JDBC type: -9
at org.hibernate.dialect.TypeNames.get(TypeNames.java:76)
at org.hibernate.dialect.TypeNames.get(TypeNames.java:99)
at org.hibernate.dialect.Dialect.getHibernateTypeName(Dialect.java:592)
wie dieses Problem zu lösen, bitte helfen. Danke im Voraus !!!
Danke für die Antwort, versucht mit diesem aber der gleiche Fehler ... –
Ich habe einen anderen Vorschlag, immer noch rate ich fürchte. –