1. 环境:jdk1.4+hibernate2.0+weblogic8
一般情况下,我们建的表都会有主键,然后根据Hibernate的配置文件编写条件 有一个主键key,剩下的是Property的属性,对应的PO类也就是一个普通的javabean.然后根据HIBERNATE的轻量级session进行保存修改的操作等。
今天遇到了一张表,是没有主键的表,是一张从别处导过来的表。但是我需要用hibernate来进行操作。中间遇到一些曲折,最后觉得HIBERNATE不会搞的太麻烦吧,经过一篇博文的启发,终于找到了一种简洁的做法。
第一步:建表(略,无主键)
第二部:进行配置文件以及PO类的编写。
其中的做法就是没有主键,所以把一条记录看成一个主键,即组合主键<composite-id>
。
配置文件如下:
<hibernate-mapping>
<class name="com.cqgl.po.SaI18nLimitRulesPO" table="SA_I18N_LIMIT_RULES">
<composite-id>
<key-property name="aircompanyCode" type="java.lang.String">
<column name="AIRCOMPANY_CODE" />
</key-property>
<key-property name="aircompanyName" type="java.lang.String">
<column name="AIRCOMPANY_NAME" />
</key-property>
<key-property name="canbinClass" type="java.lang.String">
<column name="CANBIN_CLASS" />
</key-property>
<key-property name="discountFrom">
<column name="DISCOUNT_FROM" />
</key-property>
<key-property name="discountTo">
<column name="DISCOUNT_TO" />
</key-property>
<key-property name="refundTicketsRule" type="java.lang.String">
<column name="REFUND_TICKETS_RULE" />
</key-property>
<key-property name="refundTicketsRuleEn" type="java.lang.String">
<column name="REFUND_TICKETS_RULE_EN" />
</key-property>
<key-property name="changeDateRule" type="java.lang.String">
<column name="CHANGE_DATE_RULE" />
</key-property>
<key-property name="changeDateRuleEn" type="java.lang.String">
<column name="CHANGE_DATE_RULE_EN" />
</key-property>
<key-property name="endorsementRule" type="java.lang.String">
<column name="ENDORSEMENT_RULE" />
</key-property>
<key-property name="endorsementRuleEn" type="java.lang.String">
<column name="ENDORSEMENT_RULE_EN" />
</key-property>
<key-property name="remark" type="java.lang.String">
<column name="REMARK" />
</key-property>
<key-property name="createTime" type="java.util.Date">
<column name="CREATE_TIME" />
</key-property>
<key-property name="createUserId" type="java.lang.String">
<column name="CREATE_USER_ID" />
</key-property>
<key-property name="updateTime" type="java.util.Date">
<column name="UPDATE_TIME" />
</key-property>
<key-property name="updateUserId" type="java.lang.String">
<column name="UPDATE_USER_ID" />
</key-property>
</composite-id>
</class>
</hibernate-mapping>
第三部:重写实体类中的OBJECT的equals方法和hashCode并且每个实体要实现java.io.Serializable接口
JAVA文件如下:
package com.cqgl.po;
import java.util.Date;
public class SaI18nLimitRulesPO implements java.io.Serializable {
private String aircompanyCode;
private String aircompanyName;
private String canbinClass;
private String discountFrom;
private String discountTo;
private String refundTicketsRule;
private String refundTicketsRuleEn;
private String changeDateRule;
private String changeDateRuleEn;
private String endorsementRule;
private String endorsementRuleEn;
private String remark;
private Date createTime;
private String createUserId;
private Date updateTime;
private String updateUserId;
public String getAircompanyCode() {
return this.aircompanyCode;
}
public void setAircompanyCode(String aircompanyCode) {
this.aircompanyCode = aircompanyCode;
}
public String getAircompanyName() {
return this.aircompanyName;
}
public void setAircompanyName(String aircompanyName) {
this.aircompanyName = aircompanyName;
}
public String getCanbinClass() {
return this.canbinClass;
}
public void setCanbinClass(String canbinClass) {
this.canbinClass = canbinClass;
}
public String getDiscountFrom() {
return this.discountFrom;
}
public void setDiscountFrom(String discountFrom) {
this.discountFrom = discountFrom;
}
public String getDiscountTo() {
return this.discountTo;
}
public void setDiscountTo(String discountTo) {
this.discountTo = discountTo;
}
public String getRefundTicketsRule() {
return this.refundTicketsRule;
}
public void setRefundTicketsRule(String refundTicketsRule) {
this.refundTicketsRule = refundTicketsRule;
}
public String getRefundTicketsRuleEn() {
return this.refundTicketsRuleEn;
}
public void setRefundTicketsRuleEn(String refundTicketsRuleEn) {
this.refundTicketsRuleEn = refundTicketsRuleEn;
}
public String getChangeDateRule() {
return this.changeDateRule;
}
public void setChangeDateRule(String changeDateRule) {
this.changeDateRule = changeDateRule;
}
public String getChangeDateRuleEn() {
return this.changeDateRuleEn;
}
public void setChangeDateRuleEn(String changeDateRuleEn) {
this.changeDateRuleEn = changeDateRuleEn;
}
public String getEndorsementRule() {
return this.endorsementRule;
}
public void setEndorsementRule(String endorsementRule) {
this.endorsementRule = endorsementRule;
}
public String getEndorsementRuleEn() {
return this.endorsementRuleEn;
}
public void setEndorsementRuleEn(String endorsementRuleEn) {
this.endorsementRuleEn = endorsementRuleEn;
}
public String getRemark() {
return this.remark;
}
public void setRemark(String remark) {
this.remark = remark;
}
public Date getCreateTime() {
return this.createTime;
}
public void setCreateTime(Date createTime) {
this.createTime = createTime;
}
public String getCreateUserId() {
return this.createUserId;
}
public void setCreateUserId(String createUserId) {
this.createUserId = createUserId;
}
public Date getUpdateTime() {
return this.updateTime;
}
public void setUpdateTime(Date updateTime) {
this.updateTime = updateTime;
}
public String getUpdateUserId() {
return this.updateUserId;
}
public void setUpdateUserId(String updateUserId) {
this.updateUserId = updateUserId;
}
// 注意这种情况下 我们需要重写equals和hashCode
public boolean equals(Object object) {
return true;
}
public int hashCode() {
return 1;
}
}
进行Hibernate的config文件配置,把实体类加入到映射中去,就可以进行到相应的查询操作了。更新修改操作还没有尝试,可能还是需要一些配置吧。
参考: http://blog.csdn.net/zoucui/archive/2009/03/04/3955931.aspx
分享到:
相关推荐
6. **用Hibernate自动生成配置文件**:选择数据库中的目标表,如`t_user`,通过右键菜单选择“HibernateReverseEngineering”,根据提示逐步填写相关信息,包括主键类型、对应的Java类名及包名等,最后点击“Finish...
有了以上配置,你就可以在程序中通过 Hibernate API 来操作这个联合主键的实体类了,例如增删改查等操作。 接下来,我们讨论 `inverse` 属性的影响。`inverse` 属性用于控制在一个关联关系中,哪一方负责维护关联...
配置时需要指定Hibernate的配置文件(如`hibernate.cfg.xml`),以及实体类所在的包名。 - **DataSource**:定义数据源,这是连接数据库的关键。可以使用Apache的Commons DBCP或C3P0等连接池。 - **...
在MyEclipse中,你可以使用Hibernate工具或手动编写代码来执行CRUD操作。例如,保存一个使用联合主键的实体: ```java Session session = HibernateUtil.getSessionFactory().openSession(); Transaction tx = ...
本篇文章将详细讲解如何使用Hibernate通过配置文件反向生成数据库的所有配置文件,以及涉及的相关步骤和技术要点。 首先,Hibernate的反向工程(Reverse Engineering)功能可以帮助开发者从现有的数据库中生成实体...
当Hibernate和Struts2结合使用时,我们可能还需要在Struts2的配置文件中添加对Hibernate的依赖,例如配置一个数据源插件,以便在Action中方便地获取SessionFactory并进行数据库操作。这样,我们在业务逻辑处理时,就...
综上所述,掌握Hibernate4 jar包的使用和配置文件的编写,对于Java开发者来说是提升开发效率和代码质量的关键。通过深入理解这些知识点,可以更好地利用Hibernate实现数据库操作的自动化,从而专注于业务逻辑的实现...
### Hibernate配置文件元素详解 #### 一、概述 在SSH(Spring+Struts+Hibernate)框架中,Hibernate作为持久层框架扮演着非常重要的角色。它能够实现对象关系映射(ORM),将Java对象映射到数据库表上。为了正确地...
Hibernate 4的配置文件和映射文件的编写需要遵循严格的XML格式规范,任何格式错误都可能导致配置文件无法正确加载或运行时出现异常。 总而言之,Hibernate 4的配置和使用涉及到了对配置文件的理解,对映射文件的...
本篇将详细讲解Hibernate配置文件`hibernate.cfg.xml`的创建过程以及映射文件的创建步骤。 ### Hibernate配置文件的创建 1. 创建`hibernate.cfg.xml`文件: 首先,我们需要新建一个XML文件,通常命名为`hibernate...
这个压缩包包含的是Hibernate3的所有相关包和配置文件,这对于理解并使用Hibernate3进行数据库交互非常有用。 1. **hibernate3.jar**: 这是Hibernate3的核心库文件,包含了所有的类和接口,如Session, Transaction,...
当我们在Java项目中使用Hibernate时,会遇到`hibernate-dtd`文件,它是Hibernate XML配置文件的规范,帮助IDE(集成开发环境)为用户在编写这些文件时提供自动提示和验证功能。 DTD文件通常包含了一系列声明,这些...
本文将详细介绍如何生成Hibernate配置文件和XML映射文件的辅助类,以及这个过程中的相关知识点。 首先,让我们理解Hibernate的核心组件。在Hibernate中,`hibernate.cfg.xml`是主配置文件,它包含了数据库连接信息...
本文详细介绍了如何在Hibernate中实现复合主键,包括复合主键类的定义、Hibernate映射文件的配置以及实体类的设计。通过这种方式,我们可以有效地利用复合主键来保证数据的唯一性和完整性。此外,还提供了一个简单的...
这个“NHibernate2.0 实体类和配置文件生成模板”是针对CodeSmith工具设计的,用于自动化创建与数据库表对应的实体类和配置文件,提高开发效率。 CodeSmith 是一款基于模板的代码生成工具,通过自定义模板,可以...
这个接口用于设置Hibernate所需的配置信息,如数据源、连接参数等,并根据配置文件读取信息创建`SessionFactory`。`SessionFactory`是一个重量级对象,它是整个应用中唯一需要实例化的对象,用于创建`Session`对象。...
`hibernate-configuration-3.0.dtd`文件是用于定义`hibernate.cfg.xml`配置文件的。这个文件中,开发者会定义数据库连接参数、session工厂设置、缓存策略等关键信息。例如,DTD定义了如`<session-factory>`、`...