Hibernate 中的session 的flush、reflush 和clear 方法 ,及数据库的隔离级别
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~分割线~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1. flush 方法:
说白一点:如果session 中的某个类的属性发生了改变,使用flush() 方式,去更改数据库中的记录,使其和改变后的session 中的对象一致。
打个不恰当的比方:session 这时是主动方,数据表是被动方,被动方应根据主动放的改变而改变,一保存和主动方一致。flush()就是让数据库的记录跟着session 中对象的改变而改变
<span style="font-size:14px;">/**
* flush :使用数据表中的记录和Session 缓存 中的 对象的状态保存一致,为了保持一致,则可能会发送对应的SQL 语句。
* 是为了保证缓存的记录 和数据表中的记录一致,向数据库方式SQL 语句,去改变数据库中的记录使其和session 中的
* 的一致.
*
* 1. 在transaction 的commit() 方法中: 先调用session 的flush方法,在提交事务
* 2. flush() 方法 可能会发送SQL 语句,但不会提交事务;
*
* 3. 注意: 在未提交事务或显示的调用session.flush() 方法之前,也有可能会进行flush() 操作
* ①.因为执行HQL 和QBC 时,需要保证获取的记录是最新的,因此 执行HQL 或QBC 查询,会先进行flush()操作, 以得到数据表中的最新的记录
* ②. 若记录的ID 是由底层数据库使用自增的方式生成的,则在调用save() 方法后, 就会立即方式INSERT 语句
* 因为save 方法后,必须保证对象中的ID 是 存在的!
* 但是当生成ID 的方式,换成hibernate 生成的化,就不会在transaction.commit之前在执行sql语句了
* 这就是ID 生成方式对 放送sql 语句的影响!
*/
@Test
public void testSessionFlush2(){
Person person = new Person("Zhagng", "sleeping", new Date());
session.save(person);
}
@Test
public void testSessionFlush(){
Person person = (Person) session.get(Person.class,32768);
person.setName("Jim");
Person person2 = (Person) session.createCriteria(Person.class).uniqueResult();
System.out.println(person2);
}</span>2. reflush 方法:
打个不恰当的比方:数据表是主动方,session
这时是被动方,被动方应根据主动放的改变而改变,一保存和主动方一致。reflush()就是让session 中对象跟着数据库的记录的改变而改变
/**
* refresh() :会强制发送SELECT 语句,以使Session 缓存中对象的状态和数据表中对应的记录保持一致!
*
*/
@Test
public void testRefresh(){
Person person = (Person) session.get(Person.class, 1);
System.out.println(person);
session.refresh(person);
System.out.println(person);
}3. clear()清理缓存/**
* clear():清理缓存
*/
@Test
public void testClear(){
Person person = (Person) session.get(Person.class, 1);
session.clear();
Person person2 = (Person) session.get(Person.class, 1);
}声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。
- 上一篇: Bean 的配置方式
- 下一篇:没有了
