hibernate 学习笔记二

Hibernate中对象的状态
---------------------------

是否和session关联 数据库中是否有对应记录 备注


自由状态 No No

持久化状态 Yes Yes (具有脏检查功能)

游离状态 No Yes

<dynamic-update>
如果设为true,不使用缓存内的SQL语句,动态生成Update语句(大量进行更新操作并且只修改局部时设为true)
----------------------------------------------------------------------------------------------------------------------------------

获取对象
---------------------------
get()/load()区别
1、当表中没有对应记录时,get() 返回null,而load()抛出异常
2、get()直接到数据库中去查询记录,而load()先到缓里查,如果缓存里没有再到数据库中去查
3、get()不使用代理类,而load()使用代理类[代理类(ProxyClass)一般在延迟加载时使用
HQL

Criteria

SQL
----------------------------------------------------------------------------------------------------------------------------------

级联
---------------------------
级联类型:
none:默认值,不级联;
save-update:级联保存和更新;
delete:级联删除,不依赖数据库的级联设置,通过多条delete语句实现级联删除;
delete-orphan:在级联删除的基础上做到解除关系即删除;
all:save-update和delete效果的合成;
all-delete-orphan:all和delete-orphan效果的合成;
----------------------------------------------------------------------------------------------------------------------------------

批处理操作
---------------------------
session.flush()
将session缓存中信息,写入JDBC连接
session.clear()
将缓存清空
----------------------------------------------------------------------------------------------------------------------------------


事务
---------------------------
JTA:JDBC 事务构架
采用两阶段提交协议解决分布式事务,必须要服务器支持

Flush Mode
通过FlushMode关键字改变清理缓存发生的时刻:
查询 tran.commit() session.flush()
AUTO 发生 发生 发生
COMMIT 不发生 发生 发生
NEVER 不发生 不发生 发生

并发访问问题:
1、脏读: 一个事务读取另一个事务中的数据
2、不可重复读:一个事务两次读取相同的数据内容,结果不一致
3、虚读: 一个事务两次读取相同的统计数据,结果不一致
4、第一类丢失更新:一个事务将另一个事务已提交的数据回滚掉
5、第二类丢失更新:一个事务修改掉另一个并发事务修改提交的内容

通过设置隔离级别解决并发问题:
一丢 脏读 不可重复读 二丢 虚读
1: 解决 没解决 没解决 没解决 没解决
2: 解决 解决 没解决 没解决 没解决
4: 解决 解决 解决 解决 没解决
8: 解决 解决 解决 解决 解决
Oracle只支持Read commited Serializable
悲观锁
LockMode
None:先到缓存中取数据中,缓存中没有再到数据库中取数据
READ:同时到缓存和数据库中取数据,并进行比较
UPGRADE:检索到对象后便对其加锁
UPGRADE_NOWAIT:如果要检索对象被加锁,则不等待,直接报错
WRITE:默认状态
乐观锁
在表、POJO类及映射文件中加version
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值