org.hibernate.HibernateException: Connection cannot be null when 'hibernate.dialect' not set

在Hibernate4中使用时出现的问题。

配置好Hibernate4后测试时出现Caused by: org.hibernate.HibernateException: Connection cannot be null when 'hibernate.dialect' not set

检查后hibernate.cfg.xml配置都市正确的,主要原因在于下面的代码:

Configuration cfg = new Configuration();
ServiceRegistry serviceRegistry= new ServiceRegistryBuilder().applySettings(cfg.getProperties()).buildServiceRegistry();
sessionFactory = cfg.configure().buildSessionFactory(serviceRegistry);
注意第二行的 applySettings(cfg.getProperties())是获取hibernate.cfg.xml的配置信息后设置进ServiceRegistryBuilder中,但是在设置之前的cfg(也就是Configuration)没有获取到hibernate.cfg.xml中的信息,所以在运行的时候或出现属性值未设置的情况。

知道了问题的原因所在,解决就好办了,只要在applySettings(cfg.getProperties())之前获取hibernate.cfg.xml的信息并设置到ServiceRegistryBuilder中即可,这样ServiceRegistryBuilder就可以通过这些信息来构建ServiceRegistry。可以通过Configuration的configure()方法获取的hibernate.cfg.xml中的配置信息。

解决后的代码如下:

Configuration cfg = new Configuration().configure();
ServiceRegistry serviceRegistry= new ServiceRegistryBuilder().applySettings(cfg.getProperties()).buildServiceRegistry();
sessionFactory = cfg.buildSessionFactory(serviceRegistry);

运行正常...

这是Hibernate4获取SessionFactory的方式,原来的buildSessionFactory()已经不推荐在Hibernate4中使用了。


你可能感兴趣的:(Hibernate)