hibernate持久化类和一级缓存

持久化类编写规则

1.有无参构造函数。

2.属性不能被final修饰。

3.对外提供属性的get和set方法。

4.需要提供一个持久化OID对象唯一标识对象。

主键生成策略

            <!-- <generator class="native"/>包括sequence和 identity-->
            <!-- <generator class="increment"/>适用于单线程使用,采用hibernate主键生成策略,最大id加1成为新的id-->
            <!--<generator class="identity"/>使用数据库底层主键生成策略,id自动增长,适用于mysql-->
            <!--<generator class="sequence"/> 适用于oracle -->
            <!--<generator class="uuid"/> 适用于使用字符串当主键 -->
            <!--<generator class="assigned"/> 用户自定义主键生成策略 ,手动生成id-->

持久化类三种状态

1.瞬时态,没有OID标识,没有被Session管理。

2.持久态,有OID持久化标识,被Session管理。

3.托管态,有OID持久化标识,没有被Session管理。

hibernate的一级缓存

hibernate的一级缓存是session级别的缓存,随着session的创建而产生,随着session的清除而消失,一级缓存的作用是从内存中读取数据,而不需要从硬盘中读取数据,如果一个对象的标识在缓存中存在,下次获取数据从缓存中获取,插入数据如果对象已经存在,则不发送sql语句,如果不存在,需要发送sql语句。这是利用一级缓存的快照区实现的。

package hibernate;

import java.io.Serializable;

import org.hibernate.Session;
import org.hibernate.Transaction;

public class hibernateDemo3 {
       public static void main(String[] args) {
        Session session = hibernateUtils.openSession();
        Transaction transaction = session.beginTransaction();

       Customer customer1 = (Customer) session.get(Customer.class, 1l);
       customer1.setCust_name("666");
        System.out.println(customer1);

        transaction.commit();
        session.close();

    }
}

在第一次修改的时候,是发送了update语句,第二次执行的话快照区已经存在这个对象数据,就不会发送update语句。

原文地址:https://www.cnblogs.com/yanqingguo/p/9745785.html

时间: 2024-10-16 10:02:40

hibernate持久化类和一级缓存的相关文章

3.1 hibernate持久化类及一级缓存

1.持久化类编写规则 Hibernate是持久化层的ORM映射框架,专注于数据的持久化工作. 持久化:所谓的持久化就是讲内存中的数据永久保存到关系型数据库中. 持久化类:其实所谓的持久化类指的是一个Java类与数据库表建立了映射关系,那么这个类称为是持久化类.其实,你可以简单的理解为就是一个Java类,该类通过一个映射文件与数据库的表建立了关系.持久化类的编写规则如下: 1.持久化类提供无参数构造:因为在hibernate的底层需要使用反射生成类的实例: 2.成员变量私有,提供共有get/set

Hibernate 持久化对象和一级缓存

关于如何手动创建Hibernate,Hibernate初了解已经介绍了,接下来了解持久化对象和一级缓存. Hibernate的持久化类有三种状态: 1.Transient瞬时态:持久化对象没有唯一标识OID,没有纳入Session的管理. 2.Persistent持久态:持久化对象有唯一标识OID,已经纳入到Session的管理,另外,持久化具有自动更新数据库的特点 3.Detached脱管态:持久化对象有唯一标识OID,没有纳入到Session管理. 下面给出一段代码来区分这三种状态: 1 /

(转) Hibernate持久化类与主键生成策略

http://blog.csdn.net/yerenyuan_pku/article/details/65462930 Hibernate持久化类 什么是持久化类呢?在Hibernate中持久化类的英文名称是Persistent Object(简称PO),PO=POJO+hbm映射配置文件. 对于Hibernate中的PO,有如下编写规则: 必须提供一个无参数的public构造方法. 所有属性要用private修饰,对外提供public的get/set方法. 在PO类必须提供一个标识属性,让它与

hibernate框架学习之一级缓存

l缓存是存储数据的临时空间,减少从数据库中查询数据的次数 lHibernate中提供有两种缓存机制 ?一级缓存(Hibernate自身携带) ?二级缓存(使用外部技术) lHibernate的一级缓存即Hibernate操作数据时所对应的临时数据存储区域,这个区域是绑定Session对象的,也就是说每开启一个Session对象,就会产生对应的一级缓存空间,当Session对象关闭时,该空间内的数据,也就是其中保存的PO对象,会转化为DO对象. lHibernate的一级缓存是Session级别的

在Hibernate框架中详谈一级缓存

在学习Hibernate的过程中我们肯定会碰上一个名词---缓存,一直都听说缓存机制是Hibernate中的一个难点,它分为好几种,有一级缓存,二级缓存和查询缓存 今天呢,我就跟大家分享分享我所理解的一级缓存 要想完美的体现出缓存机制的话,我想通过查询语句生成的sql应该就能够很清楚的看到 那些Hibernate的配置信息我就不展示了,直接看关键代码 场景:我要查询同一个对象,查询两次,观察在不同的情况下,sql语句的生成情况 我事先准备了一个HibernateUtil工具类,具体如下 pack

笔记:Hibernate 持久化类标注示例-双向1-N关系映射

1-N关系的1端持久化类 package org.drsoft.hibernate.model.oneToMany; ? ? import java.util.Date; import java.util.Set; ? ? import javax.persistence.*; ? ? @Entity @Table(name = "OneToMany_One") public class OneToManyForOneModel { @Id @Column(name = "R

笔记:Hibernate 持久化类标注说明

持久化类标注 标注 @Entity:注解声明该类是一个Hibernate的持久化类 标注 @Table:指定该类映射的表 参数 name:指定映射数据库表的名称 参数 uniqueConstraints:为持久化类所映射的表设置唯一约束,该属性的值是 @UniqueConstraint 标注数组 参数 indexes:为持久化类说映射的表设置索引,该属性的值是 @Index 标注数组 参数 catalog:设置持久化类说映射的表放入指定的 catalog 中,没有指定则放入默认 catalog

Hibernate持久化类属性映射

Hibernate充当应用程序和数据库之间的中间件,实现二者之间的交互操作,他对JDBC进行了封装,以完全面向对象的方式来操作数据. 适用于有多个数据源的情况下,不必去考虑不同数据源的操作差异. Hibernate将类型对象与数据库表建立映射关系,把类的属性映射称为数据库表的字段,Hibernate属性映射可分为简单属性映射.集合属性 映射.复合属性映射及派生属性映射.下面分别以实例介绍这几个映射及其对应的映射文件表示方式. 1.简单属性 假设有个User类,对应数据库中的User表 User类

Hibernate持久化类规则

注意事项: 提供无参的构造方法,因为在hibernate需要使用反射生成类的实例 提供私有属性,并对这些属性提供公共的setting和getting方法,因为在hibernate底层会将查询到的数据进行封装 尽量使用封装类,因为包装类和基本数据类型的默认值不一样,包装类的类型语义更加清晰,而基本数据类型不容易描述 提供唯一一个oid,与数据库表的主键对应:因为hibernate需要使用oid来判断在内存中是否存在同一个持久化类,而在Java中是通过地址来区分的是否是同一条记录 不要用final修