Java项目中使用Hibernate处理数据
发布时间:2006-02-14 10:36:04 来源:bea 网友评论 0 条 Orders,OrderItems
有时一个一个地操纵对象确实可行,但是我们希望能够级联加载和更新。现在我们来看如何做到这一点。
我们需要同时检查Order和OrderItem。就如前面所提到的,我们添加一项Product到一个Order中,它将变成一个OrderItem。Order在内部保存一个OrderItem集。我们希望保存Order,让Hibernate来做其他工作:保存OrderItem和更新所添加的Product的可用库存(数量)。听起来很复杂,但实际上非常简单。Hibernate知道如何处理一对一、一对多、多对一和多对多方式中的相关对象。我们将从映射文件开始。
Order.hbm.xml
这个映射文件非常易于理解,除了最后一个元素<set>。它表示了不同类之间的连接,在我们的例子中,这些类是Order和OrderItem。属性和子元素很容易理解:一个Set类型的字段,名为orderItems(参见上面的Order源代码),它包含类型为test.hibernate.OrderItem的对象,正如<one-to-many>子元素所解释的那样。这些对象被持久化在表order_items中,order_id列包含OrderItem类型的对象的键。
cascade="all"是一个非常重要的属性。它解释了在操纵连接到的对象时,Hibernate如何动作。在我们的例子中,当创建一个Order时,我们无疑希望它所有的OrderItem也被创建;当然,当一个Order被删除时,我们也希望它所有的OrderItem也被删除。Cascade属性还有另外三个选项(none、save-update和delete),我们将在下面的示例中看一下如何使用它们。
OrderItem.hbm.xml
这个对象比较有意思。它的实例自动在Order中创建,基本上不会存在于其外。然而,由于它们在创建Order时代表Product,所以我们需要它们。如果一项产品的价格改变了,我们无疑不希望所有相关的OrderItem以及Order的价格被改变。我们需要的只是在OrderItem创建时更新Product的可用库存。最后,当一项Order被删除时,其OrderItem也被删除,但我们不能改变Product!听上去很复杂,特别是要编写所有这些SQL语句的话。但Hibernate把它们压缩成了映射文件中的两行!
到目前为止,我们了解了关于<id>和<property>元素的一切,但<many-to-one>是一个新元素。这个元素非常简单。第一个<many-to-one>元素指出OrderItem的名为order的字段是test.hibernate.Order类型,并且通过表order_items的order_id列来引用(参见class元素的table属性)。第二个many-to-one元素类似于第一个,除了它具有cascade="save-update"属性。它在定义的内容之前进行解释。在这个例子中,我们假设Hibernate只在保存(创建)或更新(更改)OrderItem时传递Product的更改,而在删除时不传递更改。因此,上述的复杂SQL语句就被压缩为单个属性!现在这个问题解决了!
有时一个一个地操纵对象确实可行,但是我们希望能够级联加载和更新。现在我们来看如何做到这一点。
我们需要同时检查Order和OrderItem。就如前面所提到的,我们添加一项Product到一个Order中,它将变成一个OrderItem。Order在内部保存一个OrderItem集。我们希望保存Order,让Hibernate来做其他工作:保存OrderItem和更新所添加的Product的可用库存(数量)。听起来很复杂,但实际上非常简单。Hibernate知道如何处理一对一、一对多、多对一和多对多方式中的相关对象。我们将从映射文件开始。
Order.hbm.xml
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN" "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd"> <hibernate-mapping> <class name="test.hibernate.Order" table="orders"> <id name="id" type="string" unsaved-value="null" > <column name="id" sql-type="char(32)" not-null="true"/> <generator class="uuid.hex"/> </id> <property name="date"> <column name="order_date" sql-type="datetime" not-null="true"/> </property> <property name="priceTotal"> <column name="price_total" sql-type="double" not-null="true"/> </property> <set name="orderItems" table="order_items" inverse="true" cascade="all"> <key column="order_id" /> <one-to-many class="test.hibernate.OrderItem" /> </set> </class> </hibernate-mapping> |
这个映射文件非常易于理解,除了最后一个元素<set>。它表示了不同类之间的连接,在我们的例子中,这些类是Order和OrderItem。属性和子元素很容易理解:一个Set类型的字段,名为orderItems(参见上面的Order源代码),它包含类型为test.hibernate.OrderItem的对象,正如<one-to-many>子元素所解释的那样。这些对象被持久化在表order_items中,order_id列包含OrderItem类型的对象的键。
cascade="all"是一个非常重要的属性。它解释了在操纵连接到的对象时,Hibernate如何动作。在我们的例子中,当创建一个Order时,我们无疑希望它所有的OrderItem也被创建;当然,当一个Order被删除时,我们也希望它所有的OrderItem也被删除。Cascade属性还有另外三个选项(none、save-update和delete),我们将在下面的示例中看一下如何使用它们。
OrderItem.hbm.xml
这个对象比较有意思。它的实例自动在Order中创建,基本上不会存在于其外。然而,由于它们在创建Order时代表Product,所以我们需要它们。如果一项产品的价格改变了,我们无疑不希望所有相关的OrderItem以及Order的价格被改变。我们需要的只是在OrderItem创建时更新Product的可用库存。最后,当一项Order被删除时,其OrderItem也被删除,但我们不能改变Product!听上去很复杂,特别是要编写所有这些SQL语句的话。但Hibernate把它们压缩成了映射文件中的两行!
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN" "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd"> <hibernate-mapping> <class name="test.hibernate.OrderItem" table="order_items"> <id name="id" type="string" unsaved-value="null" > <column name="id" sql-type="char(32)" not-null="true"/> <generator class="uuid.hex"/> </id> <property name="orderId" insert="false" update="false"> <column name="order_id" sql-type="char(32)" not-null="true"/> </property> <property name="productId" insert="false" update="false"> <column name="product_id" sql-type="char(32)" not-null="true"/> </property> <property name="amount"> <column name="amount" sql-type="int" not-null="true"/> </property> <property name="price"> <column name="price" sql-type="double" not-null="true"/> </property> <many-to-one name="order" class="test.hibernate.Order" column="order_id" /> <many-to-one name="product" class="test.hibernate.Product" cascade="save-update" column="product_id"/> </class> </hibernate-mapping> |
到目前为止,我们了解了关于<id>和<property>元素的一切,但<many-to-one>是一个新元素。这个元素非常简单。第一个<many-to-one>元素指出OrderItem的名为order的字段是test.hibernate.Order类型,并且通过表order_items的order_id列来引用(参见class元素的table属性)。第二个many-to-one元素类似于第一个,除了它具有cascade="save-update"属性。它在定义的内容之前进行解释。在这个例子中,我们假设Hibernate只在保存(创建)或更新(更改)OrderItem时传递Product的更改,而在删除时不传递更改。因此,上述的复杂SQL语句就被压缩为单个属性!现在这个问题解决了!
- 推荐阅讯
- Simple Logging Facade for Java 1.0初版发
- EJB 3.0是Hibernate的克隆吗?
- Java服务器端编程安全必读
- 如何优化JAVA程序设计和编码,提高JAVA性能
- Java2十大经典中文图书
- java的异常处理机制
- 在LINUX下配置JAVA开发环境
- Java FTP客户端库的选择
- IBM发布Java字节码配置工具包BIPTK
- Eclipse中自动重构实现探索
- 阅读排行
- 1.Java连接SQL Server 2000
- 2.Java文件操作详解
- 3.Java控件设计入门
- 4.Java操作Excel电子表格
- 5.Java: JNI完全手册
- 6.Java命令行简介
- 7.开发J2EE应用应遵循的几点原则
- 8.Servlet与Javabean配置
- 9.Java规则引擎与其API应用详解
- 10.CLASSPATH详解
- 专题教程
- Windows Server-Windows Server文档-Windows Server新闻-Windows Ser PostgreSQL-PostgreSQL文档-PostgreSQL新闻-PostgreSQL专家
- WebLogic-WebLogic文档-WebLogic新闻-WebLogic专家 FreeBSD-FreeBSD文档-FreeBSD新闻-FreeBSD专家
- Linux-内核 GUI KDE Gnome DNS FTP 安全 安装-Linux专区 Windows-AD IIS ServerCore 虚拟化 安全 HPC-Windows专区
- 大话G游 专题:手机病毒揭密
- ARP攻击防范与解决方案 路由故障处理手册
