Hibernate中对无主键表的操作

Db2 表:Test 只有一个测试字段:name character(10)

Hibernate的hbm文件:Test.hbm.xml

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping SYSTEM "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd" >
<hibernate-mapping>
<class name="Test" table="test">
 <composite-id name="testpk" class="Testpk" unsaved-value="any">
  <key-property name="name" column="name" type="string"/>
    </composite-id>
 </class>
</hibernate-mapping>

 

Test.java

 

import java.io.Serializable;

public class Test implements Serializable{

 private Testpk testpk;
 
 public void setTestpk(Testpk value){
  this.testpk=value;
 }
 
 public Testpk getTestpk(){
  return this.testpk;
 }
 
}

Testpk.java

import java.io.Serializable;

public class Testpk implements Serializable{
 
 private String name;
 public String getName()
 {
  return this.name;
 }
 
 public void setName(String value){
  this.name=value;
 }
 
 public boolean equals(Object other) {
      Testpk that = (Testpk) other;
    
      return this.name.equals(that.name);
      }
   
      /**
    * Returns the hash code for the key.
    */
  
      public int hashCode() {
    
      return (this.name.hashCode());
     
      }

}

测试代码:

Test t=new Test();
  Testpk tpk=new Testpk();
  tpk.setName("test000000");
  t.setTestpk(tpk);
  session.save(t);

最后值得注意的是当要load的时候,不能简单的Test t=(Test)session.load(Test.class,"test000000"); 而使用一个Testpk作为一个实体类的标识符。

所以应该这么写:

Testpk tpk=new Testpk();
 tpk.setName("test000000");
 Test t=(Test)session.load(Test.class,tpk);

 

环境DB2、Eclipise、Hibernate2测试成功

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值