Hibernate框架
文章目录
1.一款非常优秀的ORM框架 同时 也是一种优秀的持久化框架 全自动
ORM:Object - Relation -Mapping 对象关系映射
作用:类–表 属性–字段 反射生成SQL语句 及 动态封装成对象
2.Hibernate中两种文件:
映射文件 :数据库对象和实体对象关系: 类-表 属性-字段 一对一 一对多 多对多等关联关系
配置文件:连接数据库信息 用户名 密码 驱动 url ,引入映射文件 方言。xml,properties
3.持久化:实现方式:jdbc io 序列化
瞬时状态和持久状态相互转换的过程
4.Hibernate执行原理
a.加载配置文件 cfg.xml
b.创建SessionFactory —映射文件
c.创建Session
d.开启事务
e.持久化 ----根据解析的映射文件,反射生成SQL 使用JDBC执行SQL
f.提交事务
g.关闭session
5.HQL,关联关系,Criteria,本地SQL,命名SQL,命名HQL,离线查询
6.缓存机制:
6.1 什么是缓存:
6.2 为什么使用缓存:
6.3 缓存的一般工作原理:
6.4《 一级缓存》 session级别 (默认开启)
6.4.1一级缓存的API
注意:query.list()方法不会触发一级缓存,而query.iterate()会触发一级缓存
6.5《 二级缓存》 sessionFactory级别 需要配置(a.配置文件二级缓存true b.配置文件中指定驱动类 c.在映射文件中,配置缓存节点)
6.5.1 二级缓存的配置步骤
6.5.2 实体类配置文件的cache标签
cache的三个属性
6.6 一二级缓存的对比
6.7 一二级缓存总结
query缓存 (a.在二级缓存配置的基础上 b.配置文件中配置查询缓存 c.在代码中 Query执行前 setCacheMode(true))
7.调优:
抓取策略,lazy,批量抓取,批量处理
8.JPA与hibernate的关系
jpa是java oersistence api—一种标准的借口
hibernate是其更强大的实现
实际开发中优先考虑jpa的注解(javax.***)
9.hibernate的注解分类:
① 类级别注解:(打在类方法上)
@Entity实体类
@Table
@Embeddable嵌入类
② 属性级别注解:(打在属性字段上||写在属性的get方法上)
@Id
@Column
@GenerattedValue
@Embedded
@EmbeddedId
@Transient
@SequenceGenerator
@Lob
@Version
@Basic
③ 表级关系映射注解:
①-① @Entity注解
一个实体类代表一个表,此注解打在实体类的类方法上
注 : 在建好实体类之后要在hibernate配置文件里添加注册信息(完整类名)
测试类生成对应表结构:
测试类提交事务:
①-② @Table注解:
一个实体类代表一个表,此注解打在实体类的类方法上(与@Entity在同一位置)
Schema与catalog的区别:(包含关系)
@Entity注释指名这是一个实体Bean,@Table注释指定了Entity所要映射带数据库表
①-③@Embeddable注解:
嵌入类注解,打在嵌入类的类方法上,表示这个类的对象在另一个实体类中充当属性
步骤:建立嵌入类并打上标签、在实体类中加入嵌入类类型的属性。
结果:嵌入类的各个属性都进入到了实体类中。
②-① @Id注解:
②-② @GeneratedValue注解(主键生成策略):