2016-06-30 4 views
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 !!!

Antwort

0

Eine weitere Vermutung :-), versuchen die Unternehmen Informationen

Query query = session 
    .createSQLQuery("Exec dbo.GetUserDetails @userId=:userId") 
    .addEntity(UserInfo.class) 
    .setParameter("userId", 14);   

Genommen from here hinzuzufügen.

+0

Danke für die Antwort, versucht mit diesem aber der gleiche Fehler ... –

+0

Ich habe einen anderen Vorschlag, immer noch rate ich fürchte. –