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

Hibernate无主键配置文件编写的更多相关文章

  1. Hibernate(三)结构-配置文件-实体映射及配置文件

    一.体系结构 SessionFactory:属于单一数据库的编译过的映射文件的一个线程安全的,不可变的缓存快照.Session的工厂.有可能持有一个可选的数据缓存可以进程级别或者群级别保存可以在事务中 ...

  2. Hibernate主键生成策略详解

    转载自:http://blog.csdn.net/wanghuan203/article/details/7562395 hibernate提供的主键生成策略,使我们可以在实体类的映射xml文件中设定 ...

  3. 160727、自定义hibernate主键生成策略生成字符串+数字自增长

    需求:需要自增长注解如MyId0001.MyId0002.MyId0003 实现:实现这个接口org.hibernate.id.IdentifierGenerator 一.MyIdGenerator. ...

  4. hibernate主键生成机制与save返回

    主键生成机制为assigned时,save之后通过get得不到id(主键),使用identity可以. hibernate主键生成机制1) assigned主键由外部程序负责生成,无需Hibernat ...

  5. Hibernate 主键策略

    Hibernate主键生成策略 .自动增长identity 适用于MySQL.DB2.MS SQL Server,采用数据库生成的主键,用于为long.short.int类型生成唯一标识 使用SQL ...

  6. sql语句删除由于无主键导致完全重复的数据方法

    sql语句删除由于无主键导致完全重复的数据方法 select distinct * into #Tmp from t_column drop table t_column select * into ...

  7. Log4j2 — Log4j2导入、LogEvent、配置文件编写及路径

    1. Log4j2的导入 首先到http://logging.apache.org/log4j/2.x/download.html 上下载最新的log4j2的jar包,然后再eclipse中加入log ...

  8. Hibernate主键自增策略

    hibernate 主键生成策略配置: 通过 实体类映射文件中 <id>元素的 子元素 <generator> 元素进行配置 <generator> 常用配置: ( ...

  9. Postgres——pgadmin复制无主键单表至本地数据库

    数据库中存在无主键单表gongan_address_all ,需要将余杭区数据导出成另外一张表,因为数据量太大,sql语句效率太差. 通过sql语句查询出余杭区数据,并导出成csv,sql等格式,再导 ...

随机推荐

  1. ZooKeeper本身是一个分布式应用程序,为写入分布式应用程序提供服务。

    ZooKeeper本身是一个分布式应用程序,为写入分布式应用程序提供服务. 作为ZooKeeper架构的一部分的每个组件在下表中进行了说明. 部分 描述 Client(客户端) 客户端,我们的分布式应 ...

  2. C# 7 新特性-2

    在之前的C# 7 新特性博客中,我们谈到了Tuples,Record Type和Pattern Matching.这些都是C#新特性中最可能出现的.在本博客中,我们会提到更多的一些特性,虽然这些特性不 ...

  3. mac 安装PyQt5

    PyQt5官方安装教程指出2种安装方法: Installing from Wheels Building and Installing from Source 网上搜罗的大多是按照第二种方法安装的,本 ...

  4. HTMLTestRunner美化

    https://www.cnblogs.com/findyou/p/6925733.html 参考这个,美化的不错,进入了汉化,及加入了一些样式,

  5. ubuntu_software_install

    1.atom PPA安装 命令行上依次输入即可完成安装: sudo add-apt-repository ppa:webupd8team/atom sudo apt-get update sudo a ...

  6. Linux中断(interrupt)子系统之一:中断系统基本原理

    这个中断系列文章主要针对移动设备中的Linux进行讨论,文中的例子基本都是基于ARM这一体系架构,其他架构的原理其实也差不多,区别只是其中的硬件抽象层.内核版本基于3.3.虽然内核的版本不断地提升,不 ...

  7. javascript快速入门10--运算符,语句

    一元运算符 一元运算符只有一个参数,即要操作的对象或值.它们是 ECMAScript 中最简单的运算符. delete 运算符删除对以前定义的对象属性或方法的引用.例如: var obj = new ...

  8. 验收测试 - WebDriver 5

    验收测试 - WebDriver - 配置 什么是WebDriver 这样说好了,它翻译起来就是Web驱动,用我的经验来说,它就是驱动浏览器运行的一个驱动器 有什么作用? 就像一个司机可以驱动一台汽车 ...

  9. 入侵者已经拿到了主机的管理员权限,请你列举几种留后门的方法:(windows和LINUX系统均可)

    Webshell后门 XSS后门 远控后门&rootit(windows&LINUX) SSH后门 SHIFT终端服务器后门 系统用户账号克隆 SQL数据库扩展存储型后门 SQL数据库 ...

  10. 使用zbar 解码二维码 条形码

    #!/usr/bin/env python # coding: u8 import os import zbar import Image import urllib import uuid def ...