2015-10-09 3 views
2

Я делаю небольшой проект с использованием спящего режима и MySQL.im получает эту ошибкуorg.hibernate.HibernateException: Hibernate Диалект должен быть явно установлен

org.hibernate.HibernateException: Hibernate Dialect must be explicitly set 
    at org.hibernate.dialect.DialectFactory.determineDialect(DialectFactory.java:57) 
    at org.hibernate.dialect.DialectFactory.buildDialect(DialectFactory.java:39) 
    at org.hibernate.cfg.SettingsFactory.determineDialect(SettingsFactory.java:409) 
    at org.hibernate.cfg.SettingsFactory.buildSettings(SettingsFactory.java:119) 
    at org.hibernate.cfg.Configuration.buildSettings(Configuration.java:2006) 
    at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1289) 
    at com.sla.tecprof.daoImpl.LoginDAOImpl.getUser(LoginDAOImpl.java:22) 
    at com.sla.tecprof.bdImpl.LoginBDImpl.getUser(LoginBDImpl.java:28) 
    at com.sla.tecprof.bdImpl.LoginBDImpl$$FastClassByCGLIB$$798cbe95.invoke(<generated>) 
    at net.sf.cglib.proxy.MethodProxy.invoke(MethodProxy.java:149) 
    at org.springframework.aop.framework.Cglib2AopProxy$CglibMethodInvocation.invokeJoinpoint(Cglib2AopProxy.java:689) 
    at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:150) 
    at org.springframework.orm.hibernate3.HibernateInterceptor.invoke(HibernateInterceptor.java:111) 
    at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172) 
    at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:106) 
    at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172) 
    at org.springframework.aop.framework.adapter.ThrowsAdviceInterceptor.invoke(ThrowsAdviceInterceptor.java:124) 
    at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172) 
    at org.springframework.aop.framework.Cglib2AopProxy$DynamicAdvisedInterceptor.intercept(Cglib2AopProxy.java:622) 
    at com.sla.tecprof.bdImpl.LoginBDImpl$$EnhancerByCGLIB$$9f1f562a.getUser(<generated>) 
    at com.sla.tecprof.action.LoginAction.validateUser(LoginAction.java:53) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:497) 
    at org.apache.struts.actions.DispatchAction.dispatchMethod(DispatchAction.java:270) 
    at org.apache.struts.actions.DispatchAction.execute(DispatchAction.java:187) 
    at org.springframework.web.struts.DelegatingActionProxy.execute(DelegatingActionProxy.java:113) 
    at org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:431) 
    at org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:236) 
    at org.apache.struts.action.ActionServlet.process(ActionServlet.java:1196) 
    at org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:432) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:647) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:728) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222) 
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123) 
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) 
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171) 
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99) 
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:936) 
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407) 
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1004) 
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589) 
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:312) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
    at java.lang.Thread.run(Thread.java:745) 

` моего кода, я думаю, что ошибка в buildSessonfactory.Is Какой короткий способ проверить DB соединение успех или не

List<Login> list = new ArrayList<Login>(); 
     SessionFactory sessionFactory = new Configuration().buildSessionFactory(); 
     Session session = sessionFactory.openSession(); 
     Query query = session.createQuery("From Login lg where lg.userName = :userName and lg.password = password "); 
     query.setParameter("userName", login.getUserName()); 
     query.setParameter("password", login.getPassword()); 
     list = query.list(); 

пожалуйста, помогите

Мой конфигурационный файл: -

<beans> 
<bean id="hibernateDataSourse" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> 
    <property name="driverClassName" value="com.mysql.jdbc.Driver" /> 
    <property name="url" value="jdbc:mysql://localhost:3306/tdp_management_system" /> 
    <property name="username" value="root" /> 
    <property name="password" value="root" /> 
</bean> 

<bean id="mySessionFactory" 
    class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean"> 
    <property name="dataSource" ref="hibernateDataSourse" /> 
    <property name="annotatedClasses"> 
     <list> 
      <value>com.sla.tecprof.domain.Login</value> 
     </list> 
    </property> 
    <property name="hibernateProperties"> 
     <props> 
      <prop key="hibernate.dialect"> org.hibernate.dialect.MySQLDialect</prop> 
      <prop key="hibernate.show_sql">true</prop> 
      <prop key="hibernate.hbm2ddl.auto">update</prop> 
     </props> 
    </property> 
</bean> 
+0

Я думаю, вы используете Spring, почему эта линия есть? SessionFactory sessionFactory = new Configuration(). BuildSessionFactory(); Вы уже создали один sessionFactory по имени mySessionFactory, попробовав его использовать. –

+0

Да им, используя Spring sir. im new hibernate. Я просто использую его для создания объекта sessionFactory. – SkyMicro

+0

. Проверьте, находится ли ваш файл hibernate.cfg.xml в вашем пути к классам. В противном случае SessionFactory sessionFactory = new Configuration(). BuildSessionFactory(); не удается найти файл конфигурации по умолчанию. Или вы можете указать местоположение hibernate.cfg.xml – SerMintt

ответ

1

вы не использовали SessionFactory Bean, определенный в файле XML яровой, вы использовали у наш файл конфигурации по умолчанию вместо весеннего компонента в качестве вашего SessionFactory. Проверьте свой hibernate.cfg.xml файл, вы не указали здесь свой номер hibernate.dialect.

Единственное, что я должен сказать, это то, что вы не в структуре spring-mvc. Итак, следуйте структуре mvc и используйте фабрику сеансов, определенную как весенние бобы. Используйте инъекцию пружинной зависимости, чтобы установить SessionFactory в свой класс java следующим образом.

@Autowired 
@Qualifier("mySessionFactory") 
private SessionFactory sessionFactory; 

Если вы не должны следовать spring-mvc, удалить SessionFactory боб сформировать файл XML весной и DataStore также. Затем определите все настройки с конфигурационным файлом hibernate.cfg.xml. Но помните, не стройте SessionFactory каждый раз при использовании. Используйте static или ThreadLogical Сессионный завод для ваших нужд.

0

Если вы инстанцировании ваш SessionFactory через традиционный/служебный класс, но не весной, вы могли бы рассмотреть, используя следующую строку:

SessionFactory sessionFactory = new Configuration().configure("hibernate.cfg.xml").buildSessionFactory(); 

Я второй @Bilbo Бэггинс, когда вы уже настроили SessionFactory в конфигурации Spring, можно очень хорошо использовать mysessionFactory боба

0

Такое исключение происходит, главным образом, если ваша служба MySQL/Oracle не запущена или соединение с конкретной машиной базы данных отключено в сети или локально не позволяет подключиться, когда вы задали диалоги Hibernate правильно. вышеуказанные вещи правильны или нет.