hibernate 连接释放策略

hibernate 中连接释放的策略hibernate. connection. release_ mode有以下四种属性:
default     :    默认方式  
on_close    :    session关闭时释放连接
after_transcation :  事务处理结束后,以事务为单位进行连接的释放
after_statement  :  每次执行后释放当前连接。
四种释放连接的颗粒度,从粗到细:
  1、采用第一种default配置,在spring中配置事务管理,由于事务颗粒度比较小,事务执行结束,也不会触发释放的操作,
直至达连接设置回收的最大超时时间才能回收连接,连接会迟迟不释放,导致连接池被占满。
  2、采用第二种on_close, 同样在spring中配置事务,连接一直等到session 关闭时才会,释放较慢
,同样会导致连接池被沾满
  3、采用after_transcation 的策略释放链接,每次事务都会释放链接。采用xml配置进行全局事务管理的
配置,则不会出现连接池沾满的现象。但是如果采用注解,而某个持久层的 
Dao类未标注Transactional注解,或者xml配置中遗漏了某个dao的事务管理配置,则该Dao操作执行结束,
并不是一个事务的结束,不会释放链接,导致链接迟迟不能被释放,久而久之会导致连接池被占满。
  4、after_statement 的策略释放连接及时。但也有一个弊端,由于每一次执行都会释放连接,如果一个
事务需要几个执行操作,但第一次执行时连接就被释放,连接已归还给连接池了,第二次执行时获取新的连接,
这样就无法保证事务性了。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用 Hibernate 连接数据库需要进行以下步骤: 1. 添加 Hibernate 依赖库到项目中。 2. 配置 Hibernate 的配置文件(hibernate.cfg.xml)。 3. 定义数据表与 Java 类之间的映射关系(通过 Hibernate 的注解或者 XML 映射文件)。 4. 编写 Java 代码调用 Hibernate API 进行 CRUD 操作。 下面是一个简单的 Hibernate 连接 MySQL 数据库的示例: 1. 添加 Hibernate 依赖库到项目中: 在 Maven 项目中,可以在 pom.xml 文件中添加以下依赖: ``` <dependencies> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-core</artifactId> <version>5.4.30.Final</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.23</version> </dependency> </dependencies> ``` 2. 配置 Hibernate 的配置文件(hibernate.cfg.xml): ``` <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> <hibernate-configuration> <session-factory> <property name="hibernate.connection.driver_class">com.mysql.cj.jdbc.Driver</property> <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/test?serverTimezone=UTC</property> <property name="hibernate.connection.username">root</property> <property name="hibernate.connection.password">123456</property> <property name="hibernate.dialect">org.hibernate.dialect.MySQL8Dialect</property> <property name="hibernate.show_sql">true</property> <mapping class="com.example.User"/> </session-factory> </hibernate-configuration> ``` 3. 定义数据表与 Java 类之间的映射关系: 可以使用注解方式或者 XML 映射文件的方式进行映射。 使用注解方式的示例: ``` @Entity @Table(name = "user") public class User { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Integer id; @Column(name = "name") private String name; @Column(name = "age") private Integer age; // 省略 getter 和 setter 方法 } ``` 4. 编写 Java 代码调用 Hibernate API 进行 CRUD 操作: ``` // 加载 Hibernate 配置文件 Configuration configuration = new Configuration().configure(); // 创建 SessionFactory SessionFactory sessionFactory = configuration.buildSessionFactory(); // 创建 Session Session session = sessionFactory.openSession(); // 开启事务 Transaction transaction = session.beginTransaction(); // 新增用户 User user = new User(); user.setName("张三"); user.setAge(20); session.save(user); // 提交事务 transaction.commit(); // 关闭 Session session.close(); // 关闭 SessionFactory sessionFactory.close(); ``` 以上代码实现了向数据库中插入一条数据的操作,其他的 CRUD 操作也类似。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值