- 浏览: 268624 次
- 性别:
- 来自: 新乡
文章分类
- 全部博客 (227)
- servciemix (10)
- db (18)
- javaTools (4)
- hibernate (31)
- web (3)
- spring (14)
- design pattern (4)
- java security (3)
- portal (1)
- ejb (6)
- session (2)
- java_lang (21)
- jbpm (29)
- struts (7)
- orgRights (2)
- project manager Jira (7)
- 跨库事务 (2)
- mysql (14)
- ubuntu (7)
- osgi (9)
- maven ant make (4)
- 分布式 高并发 高性能 (5)
- virgo-dm_server (0)
- osgi web (3)
- platform (1)
- smooks (1)
- business (1)
- 职场生涯 (14)
- Java编码格式 (2)
- web服务 (1)
- 计算机使用 (1)
- 健康工作生活的保障,工作中务必抛掉的不良心态 (4)
- 电信-网络监控 (1)
- 多线程-multithread (1)
- 海量数据-高性能 (2)
- Mybatis (1)
- web开发平台研发 (0)
- oracle (0)
- 应用服务器调优 (0)
- web前端 (0)
- servlet-jsp (0)
- tomcat (2)
- newtouch (1)
- portal_liferay (2)
- version control (1)
- apm-impact (2)
- tools (1)
- 研发管理 (1)
- 电商业务 (1)
- 生鲜电商市场调查 (0)
- PBX (0)
- 房东 (0)
最新评论
-
lifuchao:
...
权限问题 -
Branding:
谢谢,受教了,另外,CONN AS SYSDBA,必须是在操作 ...
Oracle密码忘记了怎么办? -
zhuchao_ko:
...
Portal实现原理 -
败类斯文:
不知道改哪里。。。木有见到红色。。表示悟性低了、、
jira error: Neither the JAVA_HOME nor the JRE_HOME environment variable is defin -
c__06:
正文:假如事务我是这样定义的: <tx:method n ...
Spring中Transactional配置
*
概述Hibernate equals()方法
* http://developer.51cto.com 2009-09-23 09:47 佚名 中国IT实验室 我要评论(0)
这里介绍Hibernate equals()方法,在java语言中,对象标识符是由每个对象都持有的Hibernate equals()方法(以及相关的hashCode()方法来定义的。
在向大家详细介绍Hibernate equals()方法之前,首先让大家了解下Java应用程序,然后全面介绍Hibernate equals()方法。
当对象持久化到数据库中时,对象的标识符总时很难被恰当的实现。尽管如此,问题其实完全是由存在着在保存之前不持有ID的对象的现象衍生而来的。我们可以通过从诸如Hibernate这样的对象—关系映像框架手中取走指派对象ID的职责来解决这个问题。相对的,一旦对象被实例化,它就应该被指派一个 ID.这使对象标识符变成简单而不易出错,也减少了领域模型中需要的代码量。
企业级Java应用程序常常把数据在java对象和关系型数据库之间来回移动。从手动编写SQL代码到使用诸如Hibernate这样的成熟的对象 ——关系映像(ORM)解决方案,有很多种方法可以实现这个过程。无论你采用什么样的技术,一旦你开始将java对象持久化到数据库中,对象标识符都将成为一个复杂而且难以管理的课题。可能出现的情况是:你实例化了两个不同的对象,而它们却代表了数据库中的同一行。为了解决这个问题,你可能采取的措施是在你的持久化对象中实现equals() 和hashCode()这两个方法,可是要恰当的实现这两个方法比乍看之下要有技巧一些。让问题更糟糕的是,那些传统的思路(包括Hibernate官方文档所提倡的那些)对于新的工程并不一定能提出最实用的解决方案。
对象标识在虚拟机(VM)中和在数据库中的差异是问题滋生的温床。在虚拟机中,你并不会得到对象的id,你只是简单的持有对象的直接引用。而在幕后,虚拟机确实给每个对象指派了一个8字节大小的id,这个id才是对象的真实引用。当你将对象持久化到数据库中的时候,问题开始产生了。假定你创建了一个 Person对象并将它存入数据库(我们可以叫它person1)。而你的其它某段代码从数据库中读取了这个Person对象的数据并将它实例化为另一个新的Person对象(我们可以叫它Person2)。现在你的内存中有了两个映像到数据库中同一行的对象。一个对象引用只能指向它们俩的其中一个,可是我们需要一种方法来表示这两个对象实际上表示着同一个实体。这就是(在虚拟机中)引入对象标识符的原因。
在java语言中,对象标识符是由每个对象都持有的Hibernate equals()方法(以及相关的hashCode()方法)来定义的。无论两个对象(引用)是否为同一个实例,Hibernate equals()方法都应该能够判别出它们是否表示同一个实体。hashCode()方法和Hibernate equals()方法有关联是因为所有被判断等价(equal)的对象都应该返回相同的哈希值(hashCode)。在缺省实现中,Hibernate equals()方法仅仅比较对象的引用,一个对象和它自身是等价的,而和其它任何实例都不等价。对于持久化对象来说,重写这两个方法,让代表着数据库中同一行的两个对象被判为等价是很重要的。而这对于java中的Collection数据结构(Set,Map和List)的正确工作更是尤为重要。
为了阐明实现equal()和hashCode()的不同途径,让我们一起考虑一个准备持久化到数据库中的简单对象Person.
1. public class Person {
2. private Long id;
3. private Integer version;
4. public Long getId() { return id; }
5. public void setId(Long id) {
6. this.id = id;
7. }
8. public Integer getVersion() {
9. return version;
10. }
11. public void setVersion(Integer version) {
12. this.version = version;
13. }
14. // person-specific properties and behavior
15. }
在这个例子中,我们遵循了同时持有id字段和version字段的最佳实践。Id字段保存了在数据库中作为主键使用的值,而version字段则是一个从0开始增长的增量,随着对象的每次更新而变化(它帮助我们避免并发更新的问题)。为了看的更清楚,我们也一起看一下Hibernate把这个对象持久化到数据库的映像文件。
1. <?XML version="1.0"?>
2. <hibernate-mapping package="my.package">
3. <class name="Person" table="PERSON">
4. <id name="id" column="ID" unsaved-value="null">
5. <generator class="sequence">
6. <param name="sequence">PERSON_SEQ</param>
7. </generator>
8. </id>
9. <version name="version" column="VERSION" />
10. <!-- Map Person-specific properties here. -->
11. </class>
12. </hibernate-mapping>
【编辑推荐】
1. Hibernate Util简单讨论
2. 详解优化Hibernate性能经验
3. 概述Hibernate dbcp连接池使用方法
4. 浅析Hibernate.cfg.xml配置
5. Hibernate Shard基础分析
【责任编辑:志京 TEL:(010)68476606】
原文:概述Hibernate equals()方法
标 签: Hibernate equals()方法
上一篇: 对Hibernate一级缓存与二级缓存的解析 下一篇: 教你如何更简单的理解Hibernate框架
网友评论
查看所有评论(0)
通行证: 密码: 注册通行证
发表评论请注意语言文明
概述Hibernate equals()方法
* http://developer.51cto.com 2009-09-23 09:47 佚名 中国IT实验室 我要评论(0)
这里介绍Hibernate equals()方法,在java语言中,对象标识符是由每个对象都持有的Hibernate equals()方法(以及相关的hashCode()方法来定义的。
在向大家详细介绍Hibernate equals()方法之前,首先让大家了解下Java应用程序,然后全面介绍Hibernate equals()方法。
当对象持久化到数据库中时,对象的标识符总时很难被恰当的实现。尽管如此,问题其实完全是由存在着在保存之前不持有ID的对象的现象衍生而来的。我们可以通过从诸如Hibernate这样的对象—关系映像框架手中取走指派对象ID的职责来解决这个问题。相对的,一旦对象被实例化,它就应该被指派一个 ID.这使对象标识符变成简单而不易出错,也减少了领域模型中需要的代码量。
企业级Java应用程序常常把数据在java对象和关系型数据库之间来回移动。从手动编写SQL代码到使用诸如Hibernate这样的成熟的对象 ——关系映像(ORM)解决方案,有很多种方法可以实现这个过程。无论你采用什么样的技术,一旦你开始将java对象持久化到数据库中,对象标识符都将成为一个复杂而且难以管理的课题。可能出现的情况是:你实例化了两个不同的对象,而它们却代表了数据库中的同一行。为了解决这个问题,你可能采取的措施是在你的持久化对象中实现equals() 和hashCode()这两个方法,可是要恰当的实现这两个方法比乍看之下要有技巧一些。让问题更糟糕的是,那些传统的思路(包括Hibernate官方文档所提倡的那些)对于新的工程并不一定能提出最实用的解决方案。
对象标识在虚拟机(VM)中和在数据库中的差异是问题滋生的温床。在虚拟机中,你并不会得到对象的id,你只是简单的持有对象的直接引用。而在幕后,虚拟机确实给每个对象指派了一个8字节大小的id,这个id才是对象的真实引用。当你将对象持久化到数据库中的时候,问题开始产生了。假定你创建了一个 Person对象并将它存入数据库(我们可以叫它person1)。而你的其它某段代码从数据库中读取了这个Person对象的数据并将它实例化为另一个新的Person对象(我们可以叫它Person2)。现在你的内存中有了两个映像到数据库中同一行的对象。一个对象引用只能指向它们俩的其中一个,可是我们需要一种方法来表示这两个对象实际上表示着同一个实体。这就是(在虚拟机中)引入对象标识符的原因。
在java语言中,对象标识符是由每个对象都持有的Hibernate equals()方法(以及相关的hashCode()方法)来定义的。无论两个对象(引用)是否为同一个实例,Hibernate equals()方法都应该能够判别出它们是否表示同一个实体。hashCode()方法和Hibernate equals()方法有关联是因为所有被判断等价(equal)的对象都应该返回相同的哈希值(hashCode)。在缺省实现中,Hibernate equals()方法仅仅比较对象的引用,一个对象和它自身是等价的,而和其它任何实例都不等价。对于持久化对象来说,重写这两个方法,让代表着数据库中同一行的两个对象被判为等价是很重要的。而这对于java中的Collection数据结构(Set,Map和List)的正确工作更是尤为重要。
为了阐明实现equal()和hashCode()的不同途径,让我们一起考虑一个准备持久化到数据库中的简单对象Person.
1. public class Person {
2. private Long id;
3. private Integer version;
4. public Long getId() { return id; }
5. public void setId(Long id) {
6. this.id = id;
7. }
8. public Integer getVersion() {
9. return version;
10. }
11. public void setVersion(Integer version) {
12. this.version = version;
13. }
14. // person-specific properties and behavior
15. }
在这个例子中,我们遵循了同时持有id字段和version字段的最佳实践。Id字段保存了在数据库中作为主键使用的值,而version字段则是一个从0开始增长的增量,随着对象的每次更新而变化(它帮助我们避免并发更新的问题)。为了看的更清楚,我们也一起看一下Hibernate把这个对象持久化到数据库的映像文件。
1. <?XML version="1.0"?>
2. <hibernate-mapping package="my.package">
3. <class name="Person" table="PERSON">
4. <id name="id" column="ID" unsaved-value="null">
5. <generator class="sequence">
6. <param name="sequence">PERSON_SEQ</param>
7. </generator>
8. </id>
9. <version name="version" column="VERSION" />
10. <!-- Map Person-specific properties here. -->
11. </class>
12. </hibernate-mapping>
【编辑推荐】
1. Hibernate Util简单讨论
2. 详解优化Hibernate性能经验
3. 概述Hibernate dbcp连接池使用方法
4. 浅析Hibernate.cfg.xml配置
5. Hibernate Shard基础分析
【责任编辑:志京 TEL:(010)68476606】
原文:概述Hibernate equals()方法
标 签: Hibernate equals()方法
上一篇: 对Hibernate一级缓存与二级缓存的解析 下一篇: 教你如何更简单的理解Hibernate框架
网友评论
查看所有评论(0)
通行证: 密码: 注册通行证
发表评论请注意语言文明
发表评论
-
如何使用hibernate
2012-05-24 19:21 0一、选择Hibernate还是iBATIS都有它的道理: H ... -
关于hibernate自动建表和主键的数据类型的关系
2012-02-27 16:18 1139要想让hibernate自动建表, 1、除了 <prop ... -
用Spring+Hibernate链接时,在增删改时会报错: Write operations are not allowed in read-only mod
2011-09-11 19:53 878用Spring+Hibernate链接时,在增删改时会报错: ... -
[转]hibernate延迟加载
2011-04-26 11:41 5632007-12-01 [转]hibernate延迟 ... -
Hibernate利用XDoclet自动生成配置文件
2011-04-18 18:34 795Hibernate利用XDoclet自动生 ... -
如何利用 myeclipse 生成Hibernate 配置文件
2011-04-18 18:13 1244在hibernate中,每个数据表对应的其实是一个实体类,每个 ... -
Hibernate Synchronizer是一个Eclipse插件,可以自动生成*.hbm文件、持久化类和DAOs
2011-04-18 18:00 1887Hibernate Synchronizer是一个Eclips ... -
Hibernate auto produce
2011-04-18 17:52 977Hibernate 中需要class和mapp ... -
使用动态代理实现用AOP对数据库进行操作
2011-04-12 14:11 944使用动态代理实现用AOP对数据库进行操作 2008-03-14 ... -
Hibernate中cascade与inverse属性详解
2011-04-01 16:20 934Hibernate中cascade与inverse属性详解 ... -
事务和事务边界
2011-03-31 15:44 100910.1.2 事务和事务边界 http://book.51ct ... -
事务传播行为种类
2011-03-31 15:31 815事务传播行为种类 Spring在TransactionDef ... -
Hibernate saveOrUpdate分析
2011-03-31 15:30 857* Hibernate s ... -
使用Spring AOP代理方式实现声明式事务的原理
2011-03-31 15:28 1199使用Spring AOP代理方式实 ... -
Hibernate Session缓存概述
2011-03-31 15:27 1000* Hibernate Session缓存 ... -
解说Hibernate的工作原理实例
2011-03-31 15:26 866* 解说Hibernate的工作原理实例 ... -
简述Hibernate配置连接池
2011-03-31 15:25 838* 简述Hiber ... -
简单解析J2EE数据持久层设计
2011-03-31 15:24 977* 简单解 ... -
浅析Hibernate Callback接口
2011-03-31 15:23 890* 浅析Hibernate Callbac ... -
概括潜在的Hibernate性能问题
2011-03-31 15:21 941* 概括潜在的Hibernate性能问题 ...
相关推荐
Hibernate概述:Hibernate是一个纯Java的关系型持久层框架,广泛用于数据库操作。它支持POJO模型,通过注解或XML配置进行映射,可以将Java对象映射到数据库表,从而简化数据库编程。 体系架构:Hibernate的体系架构...
#### 一、Hibernate概述 **Hibernate** 是一个面向 Java 领域的持久化框架,它属于 ORM(Object-Relational Mapping,对象关系映射)的一种实现方式。所谓“持久化”,通常指的是将程序运行时的数据状态保存至磁盘...
着重讲解了Hibernate如何通过POJO模型来表示业务对象,并且对POJO模型中的类特性提出了具体要求,例如无参构造器、标识属性、非final类的使用、持久化属性的getter和setter方法以及重写equals()和hashCode()方法。...
- **概况**:概述Hibernate的架构设计。 - **JMX整合**:介绍如何利用JMX进行监控和管理。 - **上下文相关的会话**:解释如何管理和使用会话对象。 3. **配置** - **可编程的配置方式**:通过代码配置Hibernate...
- **4.3 实现 equals() 和 hashCode() 方法** 为了确保 Hibernate 正确处理对象的唯一性,需要为持久化类实现这两个方法。 - **4.4 动态模型** 介绍如何使用 Hibernate 的动态元数据映射来处理结构不确定的数据...
3. **equals()和hashCode()方法**:解释了在使用集合时,持久化类需要正确覆盖equals()和hashCode()方法。 4. **动态模型和元组片断映射**:讨论了如何实现动态的ORM模型,以及如何使用元组片断映射到不同的数据库...
- **equals() 和 hashCode() 方法的实现**:讨论了如何正确实现这两个方法以支持 Hibernate 的对象识别机制。 - **动态模型**:介绍了如何使用 Hibernate 的动态模型功能来处理未知或可变的数据模型。 - **Tuplizer*...
- **实现equals()和hashCode()**: 确保对象比较正确。 - **动态模型**: 支持动态创建类结构。 - **Tuplizers**: 定义如何将行转换为对象。 - **EntityNameResolvers**: 自定义实体名称解析器。 #### 5. 基本的O/R...
- **equals()与hashCode()方法**:为了正确的对象比较和哈希计算,需要正确实现这两个方法。 - **动态模型**:使用动态代理技术来支持动态创建的实体类。 - **元组片段映射**:介绍了一种特殊的映射机制,用于更...
- 实现 equals()与 hashCode()方法,确保对象的比较和集合操作正确。 2.2. Dynamic(动态)模型 除了POJO模型,Hibernate还支持动态模型,它允许在运行时创建和操作数据模型,无需预先定义实体类,为灵活的数据库...
- **equals() 和 hashCode() 方法**:重写这两个方法以支持基于标识符的等价判断。 - **动态模型**:支持运行时动态创建和更新的模型。 - **Tuplizers**:使用自定义 Tuplizer 控制对象如何从结果集中加载。 #### ...
本文将针对几个常见的Hibernate错误进行深入分析,并提供相应的解决方法。这些错误包括但不限于 `org.springframework.orm.ObjectRetrievalFailureException`、`org.springframework.beans.factory....
- **实现 equals() 和 hashCode() 方法**:强调了为了正确的实体识别和缓存,持久化类需要正确地重写这两个方法。 - **动态模型**:介绍了如何使用 Hibernate 的元数据 API 来创建动态的数据库模型。 - **Tuplizers*...