hibernate连接数据库错误总结

1.could not parse configuration:hibernate.cfg.xml

<!--高版本hibernate的hibernate.cfg.xml文件 -->
 <!DOCTYPE hibernate-configuration PUBLIC 
        "-//Hibernate/Hibernate Configuration DTD 3.0//EN" 
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
上面红色这一句根据hibernate版本不同会有所不同,有可能需要改成
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">(低版本hibernate),当然,对应的hbm.xml文件头部也要修改成一样的才行。

2.no currentsessioncontext configured 

1、如果是本地事务:
    <property name="hibernate.current_session_context_class">thread</property>

  2、如果是全局事务
    <property name="hibernate.current_session_context_class">jta</property>
这样配置一下就好了!

  当然,如果获得session 对象时不使用的是 sessionFactory.getCurrentSession(),而是使用 sessionFactory.openSession()就不会出现这个错误了。

openSession()是不管任何情况都重新开启一个Session,而getCurrentSession();相对的增加了一个判断,在有Session的情况下就会直接去调用,没有session的话才会创建,如果有事务操作的话getCurrentSession();更好一些,很容易的使得一个线程只有一个session对象。

  本地事务和jta事务:

    本地事务:使用 JDBC 事务界定时,您可以将多个 SQL 语句结合到一个事务中。JDBC 事务的一个缺点是事务的范围局限于一个数据库连接。一个 JDBC 事务不能跨越多个数据库。

    jta事务:JTA是一种高层的,与实现无关的,与协议无关的API,应用程序和应用服务器可以使用JTA来访问事务。
  JTA允许应用程序执行分布式事务处理——在两个或多个网络计算机资源上访问并且更新数据,这些数据可以分布在多个数据库上。JDBC驱动程序的JTA支持极大地增强了数据访问能力。

    区别:JDBC事务控制的局限性在一个数据库连接内,但是其使用简单;JTA事务的功能强大,事务可以跨越多个数据库或多个DAO,使用较复杂。

3.老说登录错误

修改一下密码试试 

猜你喜欢

转载自blog.csdn.net/MrProfound/article/details/82117066
今日推荐