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. 关于java的关键字 transient

    我们都知道一个对象只要实现了Serilizable接口,这个对象就可以被序列化,Java的这种序列化模式为开发者提供了很多便利,我们可以不必关系具体序列化的过程,只要这个类实现了Serilizable ...

  2. 用Thunderbird以HTML发邮件,收件人却总是收到文本邮件

    要在通讯录里面,把你要发送的人设置可以接收HTML格式的邮件,那么你才能发出HTML格式. 否则,Thunderbird默认你所发的收件人无法接收HTML格式邮件.

  3. http://blog.chinaunix.net/uid-20577907-id-3519578.html

    http://blog.chinaunix.net/uid-20577907-id-3519578.html

  4. python 下载小说

    以下载官场风月小说为例: 具体代码: # coding=utf-8 import os import re from selenium import webdriver from selenium.c ...

  5. Redis 命令一

    Redis 命令用于在 redis 服务上执行操作. 要在 redis 服务上执行命令需要一个 redis 客户端.Redis 客户端在我们之前下载的的 redis 的安装包中. 1.Redis 客户 ...

  6. LINUX 和WINDOWS下的自动登录小脚本

    每天上班第一件事,就是连接公司LAB里面的机器,但首先要过一个防火墙,每次输用户名密码是很累人的事, 以下是两个脚本,可以放在启动项中,开机便自动登录 WINDOWS: @echo off ipcon ...

  7. C# 中 in,out,ref 的作用与区别

    In:过程不会改写In的内容 Out和out:传入的值不会被过程所读取,但过程可以写 ref:传入的值,过程会读,也会写 就象你把布料送到裁缝的一个收料箱(裁缝用这个区别是哪家客户) IN:这块布料, ...

  8. vue - 安装脚手架

    最后不得不屈服与虚拟DOM和框架,太方便了... 1.首先安装node:点击进入官网. 2. 安装后检测 3. 安装yarn(至于为嘛,速度呗) yarn官网,npm转yarn. 3.1 window ...

  9. lodash capitalize 首字母大写

    _.capitalize([string='']) 转换字符串首字母为大写,剩下为小写. _.capitalize('FRED'); // => 'Fred'

  10. 对象内部属性[[Class]]

    1.概述 所有的typeof返回值为‘object’的对象都包含一个内部属性[[Class]],我们将它可以看做内部的分类,而非传统面向对象意义的分类.这个属性无法直接访问,一般通过Object.pr ...