本帖最后由 小鲁哥哥 于 2018-1-12 16:42 编辑
【济南校区】JavaEE就业笔记串讲---Hibernate-part2 1.1 持久化类的编写规则
1.1.1 什么是持久化类
1.1.1.1 什么是持久化类
就是一个JavaBean,这个JavaBean与表建立了映射关系。这个类就称为是持久化类。
简单理解为 持久化类=JavaBean+映射文件。
1.1.1.2 持久化类的编写规则
需要提供无参数的构造方法。
类的属性需要私有,对私有的属性提供public的get和set方法。
提供一个唯一标识(OID)的属性与表的主键对应。
Java里面使用地址区分是否是同一个对象。数据库中是通过主键区分是否是同一个记录。Hibernate通过唯一标识区分是否在内存中是同一个对象。
类不要使用final修饰。
类中的属性尽量使用包装类类型。
1.2 主键生成策略
1.2.1 主键的类型
1.2.1.1 自然主键
自然主键指的是类的自身的属性作为主键。
1.2.1.2 代理主键
代理主键指的是不是类本身的属性作为主键。
1.2.2 Hibernate的主键生成策略
identity适用于MySQL有自动增长的数据库。sequence适用于有序列数据库Oracle。native叫做本地策略,根据底层的数据库不同自动选择使用identity还是sequence。
1.2.3 持久化类的三种状态
1.2.3.1 瞬时态
瞬时态:持久化对象没有持久化标识OID,对象没有被Session管理。
1.2.3.2 持久态(*****)
持久态:持久化对象有持久化标识OID,对象被Session管理。
1.2.3.3 脱管态
脱管态:持久化对象有持久化标识OID,对象没有被Session管理。
1.2.3.4 状态转换
【瞬时态】
获得瞬时态:
* Customer c = new Customer();
瞬时态对象转持久态:
* session.save(c); session.saveOrUpdate(c);
瞬时态对象转脱管态:
* c.setCust_id(1l);
【持久态】
获得持久态:
* session.get(),session.load()…;
持久态对象转脱管态:
* session.close(),session.clear(),session.evict(Object obj);
持久态对象转瞬时态:
* session.delete();
【脱管态】
获得脱管态:
Customer c = new Customer(); c.setCust_id(1l);
脱管态对象转持久态
* session.update(); session.saveOrUpdate();
脱管态对象转瞬时态
* c.setCust_id(null);
1.2.4 Hibernate的一级缓存
1.2.4.1 什么是一级缓存
一级缓存称为是Session级别的缓存,一级缓存的生命周期与Session是一致的。一级缓存其实由Session中的一组集合构成的。
1.2.4.2 特殊区域
1.2.5 Hibernate的事务管理
1.2.5.1 什么是事务
事务是逻辑上的一组操作,组成这组操作的各个单元要么全都成功,要么全都失败!
1.2.5.2 事务的特性
原子性:不可分割。
一致性:事务执行前后,数据的完整性保持一致。
隔离性:一个事务执行的过程中不应该受到其他事务的干扰。
持久性:事务一旦结束,数据持久到数据库。
1.2.5.3 如果不考虑隔离性,引发哪些问题?
脏读:一个事务读到另一个事务未提交的数据。
不可重复读:一个事务读到另一个事务已经提交的update数据,导致多次查询结果不一致。
虚读:一个事务读到另一个事务已经提交的insert数据,导致多次查询结果不一致。
1.2.5.5 Hibernate中设置事务隔离级别
[XML] 纯文本查看 复制代码 <!-- 设置事务的隔离级别 -->
<property name="hibernate.connection.isolation">4</property>
1.2.5.6 与线程绑定的Session的使用
[XML] 纯文本查看 复制代码 <!-- 配置与当前线程绑定的Session -->
<property name="hibernate.current_session_context_class">thread</property>
1.2.6 Hibernate的其他的API
1.2.6.1 Query:支持HQL查询
获得Query接口可以通过session.createQuery(String hql);获得。
HQL:Hibernate Query Language。Hibernate查询语言。语法与SQL是类似的。HQL中查询的是对象。
1.2.6.2 Criteria:支持QBC查询
获得Criteria接口可以通过session.createCriteria();获得。
QBC:Query By Criteria。条件查询。一种更加面向对象的方式。
1.2.6.3 SQLQuery:支持SQL查询
获得SQLQuery接口可以通过session.createSQLQuery();获得。
SQLQuery:通过SQL语句进行查询。
|