一:主键生成策略
1、sequence
<generator class="sequence">
<param name="sequence">hibernate_id</param> //
</generator>
特点:只能在支持序列的数据库中使用,如Oracle。
Hibernate生成主键时,查找sequence并赋给主键值,主键值由数据库生成,Hibernate不负责维护,使用时必须先创建一个sequence,如果不指定sequence名称,则使用Hibernate默认的sequence,名称为hibernate_sequence,前提要在数据库中创建该sequence。(因为没有安装oracle所以也不知道这个是不是这么写….)
2、identity
<id name="id" column="id">
<generator class="identity" />
</id>
特点:只能用在支持自动增长的字段数据库中使用,如MySQL。
如果使用MySQL数据库,则主键字段必须设置成auto_increment。
3、native
<id name="id" column="id">
<generator class="native" />
</id>
特点:根据数据库自动选择,项目中如果用到多个数据库时,可以使用这种方式
native由hibernate根据使用的数据库自行判断采用identity、hilo、sequence其中一种作为主键生成方式,灵活性很强。如果能支持identity则使用identity,如果支持sequence则使用sequence。
4、uuid
<id name="id" column="id">
<generator class="uuid" />
</id>
记得把主键设置成String类型的…
特点:uuid长度大,占用空间大,跨数据库,不用访问数据库就生成主键值,所以效率高且能保证唯一性,移植非常方便,推荐使用。
目前就用到这几个吧…
二:对象状态
瞬时状态 | 没有id,没有在session缓存中 |
持久化状态 | 有id,在session缓存中 |
游离|托管状态 | 有id,没有在session缓存中 |
二:一级缓存
缓存:提高效率.hibernate中的一级缓存也是为了提高操作数据库的效率.
提高效率手段1:提高查询效率
查询是先检查缓存中是否有id相同的对象
有直接返回缓存中的
提高效率手段2:减少不必要的修改语句发送
更新数据库之前先用对象与缓存中的快照做对比,不同才同步
三:事务
1、事务的隔离级别
<property name="hibernate.connection.isolation"></property>
//这里填写1 2 4 8
//分别对应读未提交、读已提交、可重复度、串行化
2、 管理事务
使用getCurrentSession方法来获得与线程绑定的session
首先需要配置.cfg.xml
<property name="hibernate.current_session_context_class">thread</property>
然后在调用这个方法