- 浏览: 1509390 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (798)
- struts2 (42)
- servlet (20)
- quartz (4)
- jquery & ajax (24)
- tomcat (5)
- javascript (15)
- struts1 (8)
- 搜索关键字及链接 (3)
- fckeditor (3)
- Apache (5)
- spring (22)
- linux (3)
- 企业应用 (8)
- 综合应用 (13)
- 服务器 (2)
- 数据库 (85)
- 性能调优 (21)
- 网络应用 (15)
- 缓存技术 (8)
- 设计模式 (39)
- 面试题 (7)
- 程序人生&前辈程序员 (29)
- java基础 (59)
- hibernate (75)
- log4j (4)
- http (11)
- 架构设计 (28)
- 网页设计 (12)
- java邮件 (4)
- 相关工具 (11)
- ognl (7)
- 工作笔记 (18)
- 知识面扩展 (12)
- oracle异常 (1)
- 正则表达式 (2)
- java异常 (5)
- 项目实践&管理 (1)
- 专业术语 (11)
- 网站参考 (1)
- 论坛话题 (2)
- web应用 (11)
- cxf&webservice (22)
- freemarker (3)
- 开源项目 (9)
- eos (1)
- ibatis (6)
- 自定义标签 (3)
- jsp (3)
- 内部非公开文档(注意:保存为草稿) (0)
- 国内外知名企业 (2)
- 网店 (3)
- 分页 (1)
- 消费者习惯 (2)
- 每日关注 (1)
- 商业信息 (18)
- 关注商业网站 (1)
- 生活常识 (3)
- 新闻 (2)
- xml&JSON (5)
- solaris (1)
- apache.common (3)
- BLOB/CLOB (1)
- lucene (2)
- JMS (14)
- 社会进程 (8)
- SSH扩展 (2)
- 消费心理 (1)
- 珠三角 (1)
- 设计文档 (1)
- XWork&webwork (1)
- 软件工程 (3)
- 数据库及链接 (1)
- RMI (2)
- 国内外知名企业&人物 (1)
最新评论
-
司c马:
简介易懂、
OutputStream和InputStream的区别 -
在世界的中心呼喚愛:
解决我的问题
Java获取客户端的真实IP地址 -
bo_hai:
都是些基本的概念呀!
SSO -
tian_4238:
哥们,你也是搞水利这块的吧。
巧用SQLQuery中的addScalar -
loveEVERYday:
java.util.Date、java.sql.Date、java.sql.Time、java.sql.Timestamp小结
乐观锁
大多数基于数据版本记录机制(version)实现,一般是在数据库表中加入一个version字段
读取数据时将版本号一同读出,之后更新数据时版本号加一,如果提交数据时版本号小于或等于数据表中
的版本号,则认为数据是过期的,否则给予更新
===
Inventory inv = (Inventory)session.load(Inventory.class, 1);
System.out.println("itemName=" + inv.getItemName());
System.out.println("version=" + inv.getVersion());
System.out.println("quantity=" + inv.getQuantity());
inv.setQuantity(inv.getQuantity() - 200);
session.update(inv);
---
Inventory inv = (Inventory)session.load(Inventory.class, 1);
System.out.println("itemName=" + inv.getItemName());
System.out.println("version=" + inv.getVersion());
System.out.println("quantity=" + inv.getQuantity());
inv.setQuantity(inv.getQuantity() - 200);
session.update(inv);
===
<hibernate-mapping>
<class name="com.bjsxt.hibernate.Inventory" table="t_inventory" optimistic-lock="version">
<id name="itemNo">
<generator class="native"/>
</id>
<version name="version"/>
<property name="itemName"/>
<property name="quantity"/>
</class>
</hibernate-mapping>
===
public class Inventory {
private int itemNo;
private String itemName;
private int quantity;
private int version;
===
Inventory inv = new Inventory();
inv.setItemNo(1001);
inv.setItemName("脑白金");
inv.setQuantity(1000);
session.save(inv);
大多数基于数据版本记录机制(version)实现,一般是在数据库表中加入一个version字段
读取数据时将版本号一同读出,之后更新数据时版本号加一,如果提交数据时版本号小于或等于数据表中
的版本号,则认为数据是过期的,否则给予更新
===
Inventory inv = (Inventory)session.load(Inventory.class, 1);
System.out.println("itemName=" + inv.getItemName());
System.out.println("version=" + inv.getVersion());
System.out.println("quantity=" + inv.getQuantity());
inv.setQuantity(inv.getQuantity() - 200);
session.update(inv);
---
Inventory inv = (Inventory)session.load(Inventory.class, 1);
System.out.println("itemName=" + inv.getItemName());
System.out.println("version=" + inv.getVersion());
System.out.println("quantity=" + inv.getQuantity());
inv.setQuantity(inv.getQuantity() - 200);
session.update(inv);
===
<hibernate-mapping>
<class name="com.bjsxt.hibernate.Inventory" table="t_inventory" optimistic-lock="version">
<id name="itemNo">
<generator class="native"/>
</id>
<version name="version"/>
<property name="itemName"/>
<property name="quantity"/>
</class>
</hibernate-mapping>
===
public class Inventory {
private int itemNo;
private String itemName;
private int quantity;
private int version;
===
Inventory inv = new Inventory();
inv.setItemNo(1001);
inv.setItemName("脑白金");
inv.setQuantity(1000);
session.save(inv);
发表评论
-
自定义用户类(UserType)的使用
2011-08-04 10:46 1881学习hibernate有段时间了,最近复习这门技术时看到了自定 ... -
技巧:利于ThreadLocal模式管理Session
2011-08-02 10:31 1271在利用Hibernate开发DAO模块时,我们和Session ... -
Hibernate中的回调与拦截机制
2011-07-27 17:31 1466在某些情况下,我们需要对实体的CURD操作进行捕获并执行一些操 ... -
HibernateTemplate中HibernateCallback的事务
2011-07-04 14:41 1455目的:使用HibernateTemplate执行execute ... -
Hibernate的复杂用法HibernateCallback
2011-07-04 14:40 1346HibernateTemplate还提供一种更加灵活的方式来操 ... -
Hibernate session FlushMode有五种属性
2011-07-04 13:59 17381、NEVER:已经废弃了,被MANUAL取代了2 MANUA ... -
数据库持久层——浅谈hibernate中的Session
2011-07-01 22:49 1680大多数情况下,Session 管理的目标聚焦于通过合理的设 ... -
详解Hibernate Session
2011-07-01 22:42 1503这里介绍Hibernate Session,Ses ... -
HttpSession与Hibernate中Session的区别
2011-07-01 22:41 1305一、javax.servlet.http.HttpSess ... -
巧用SQLQuery中的addScalar
2011-06-02 17:16 5756当我们用HQL进行子查询的时候,如select * from ... -
hibernate中SQLQuery的addEntity();方法
2011-04-13 14:48 2898如果使用原生sql语句进行query查询时,hibernate ... -
Hibernate的clear(),flush(),evict()方法详解
2011-03-24 11:18 17781.Clear 方法 无论是Load 还是 G ... -
hibernate模糊查询-Restrictions.ilike & Expression.like
2011-03-11 10:32 16369Criteria criteria = session.c ... -
Hibernate分页查询小结
2011-03-10 11:14 1834通常使用的Hibernate通常是三种:hql查询,QBC查询 ... -
current_session_context_class
2011-03-07 15:31 1300此设置的作用如下: What does sessionFac ... -
Hibernate的拦截器和监听器
2010-12-14 15:06 1393核心提示:最近项目需要,用到了Hibernate的拦截器和 ... -
孙卫琴.精通Hibernate:Java对象持久化技术详解_触发器使缓存与数据库不一致
2010-12-14 08:46 1405p198 -
孙卫琴.精通Hibernate:Java对象持久化技术详解_优化报表查询的性能
2010-12-13 17:51 1282p332 -
孙卫琴.精通Hibernate:Java对象持久化技术详解_查询结果类型
2010-12-13 17:34 1310p329 -
孙卫琴.精通Hibernate:Java对象持久化技术详解_投影查询
2010-12-13 17:31 1431p325
相关推荐
不乐观: python main.py --eval_every 1 --env gridworld --task default --n_state_bins 20 --env_size 20 --n_action_bins 4 --max_steps 100 --policy uniform --no_optimistic_updates --no_opt
另外,通过Optimistic Parallel Insert和更好的索引合并策略,提升了并发插入性能。 6. **安全增强**:MySQL 5.7强化了安全性,例如引入了更严格的默认权限设置,增强了审计日志功能,以及支持加密连接,确保数据...
10. **版本控制(Optimistic Locking / Pessimistic Locking)**:Hibernate提供了乐观锁和悲观锁机制,防止并发访问时的数据冲突。 11. **映射文件(Mapping Files)**:通常使用XML文件(如.hbm.xml)来定义对象-...
_three-point estimating_是指根据项目中每个任务的optimistic、most likely和pessimistic三个估算值,估算总成本。 在IT项目中,成本估算的重要性不言而喻。好的成本估算可以帮助项目经理和项目团队更好地进行资源...
- **Subversion的方法:** 采用“乐观锁定”(Optimistic Locking),默认情况下允许并发修改,并在提交时解决潜在冲突。 #### 四、版本库操作 **创建版本库:** - **命令行工具:** 使用`svnadmin create`命令。 ...
- **optimistic-lock**: 乐观锁定策略。 - **lazy**: 控制懒加载行为。 - **entity-name**: 实体名称。 - **check**: 用于检查约束的 SQL 表达式。 - **rowid**: 是否使用数据库支持的 ROWID。 ### 总结 通过上述...
**备注**: 管理 Cloudera Manager 实例间的对等关系。 ##### 11. CM_VERSION 表 **表名**: CM_VERSION **字段映射**: - **VERSION**: 版本号。 - **GUID**: 版本的全局唯一标识。 - **LAST_UPDATE_INSTANT**: ...
- **Optimistic locking properties**:实现乐观锁机制。 - **Property**:映射实体类中的属性。 - **Embedded objects**:嵌入式对象的映射。 - **Inheritance strategy**:继承策略的使用。 - **Mapping one-...
`hibernate_lazy_for_single_end`和`hibernate_optimistic_locking`涉及到对象状态管理和并发控制。懒加载是一种优化策略,仅在需要时才加载关联对象。乐观锁则是并发控制的一种方法,它假设在大多数情况下不会发生...
- **乐观锁(Optimistic Locking)**: 通过版本号等方式避免并发冲突。 - **Hibernate分页**: - 提供分页查询的能力。 - **Cache管理**: - 一级缓存: Hibernate内部自动管理的缓存。 - 二级缓存: 需要额外配置和...
- **乐观锁(Optimistic Locking)**:与悲观锁相反,它假设数据不会被修改,因此在提交事务时才检查是否有并发冲突。 #### 十、Hibernate分页 - **分页查询**:Hibernate提供了对分页的支持,可以通过设置查询参数...
`hibernate_optimistic_locking`文件可能讨论了Hibernate的乐观锁机制。乐观锁在读取数据时不加锁,而在更新时检查数据是否被其他事务修改,如果发现有冲突,则回滚事务。通过版本号或时间戳等方式实现,适合读多写...
在Java世界中,Hibernate是一个非常流行的ORM(对象关系映射)框架,它极大地简化了数据库操作。而二级缓存是Hibernate提升性能的关键特性之一。本文将深入探讨如何配置Hibernate使用JBoss Caching作为二级缓存,并...
二、乐观锁(Optimistic Locking) 乐观锁是一种乐观的认为资料的存取很少发生同时存取的问题,不作数据库层次上的锁定,而是通过应用程序上的逻辑实现版本控制的方法来维护正确的数据。 在 Hibernate 中,乐观锁...
CREATE TABLE optimistic_table ( id INT PRIMARY KEY, data VARCHAR(255), version NUMBER ); ``` 2. 时间戳机制:与版本号类似,时间戳机制是在表中添加一个时间戳字段,记录数据最后修改的时间。在更新数据时...
- **Optimistic locking properties:** - 乐观锁机制的实现,防止并发修改冲突。 - **Property:** - 映射实体类中的非主键属性。 - **Embedded objects:** - 如何映射嵌套对象或复合属性。 - **Inheritance ...
- **Optimistic locking properties**:实现乐观锁机制,防止并发更新问题。 - **Property**:映射实体类的属性到数据库的列。 - **Embedded objects**:处理嵌入式对象,即实体类内部的复杂属性。 - **Inheritance ...
- **Optimistic locking properties (optional)**:可选的乐观锁定属性。 - **Property**:说明如何映射实体的属性。 - **Embedded objects (aka components)**:嵌入式对象的映射。 - **Inheritance strategy**:...