hibernate 联合主键生成机制(组合主键XML配置方式)

hibernate 联合主键生成机制(组合主键XML配置方式)

如果数据库中用多个字段而不仅仅是一个字段作为主键,也就是联合主键,这个时候就可以使用hibernate提供的联合主键生成策略。

具体如下:

可以使用一个组件作为一个实体类的标识符。你的组件类必须满足以下要求:

不能使用一个 IdentifierGenerator 产生组合关键字。一个应用程序必须分配它自己的标识符。

具体做法如下步骤:

1.写一个包含表中联合主键的所有字段的类,作为主键类,实例如下:

package com.seed.lee.model;

/** 
* 这个类作为Person类的(组合主键)主键类 

* @author Administrator 

*/ 
public class PersonUionPKID implements java.io.Serializable {

private String firstName;

private String secondName;

public String getFirstName() { 
        return firstName; 
    }

public void setFirstName(String firstName) { 
        this.firstName = firstName; 
    }

public String getSecondName() { 
        return secondName; 
    }

public void setSecondName(String secondName) { 
        this.secondName = secondName; 
    }

@Override 
    public boolean equals(Object obj) { 
        if(obj instanceof PersonUionPKID){ 
            PersonUionPKID pk=(PersonUionPKID)obj; 
            if(this.firstName.equals(pk.firstName)&&this.secondName.equals(pk.secondName)){ 
                return true; 
            } 
        } 
        return false; 
    }

@Override 
    public int hashCode() { 
        return super.hashCode(); 
    }

}

这里要特别注意,如hibernate API文档所述,主键类必须实现java.io.Serializable接口,而且推荐用自己的方法override    equals() 和hashCode()方法,保证主键的唯一性.

2.再写一个类与表字段相当的类,这个类里面不一定要包含表主键的所有字段,实例如下:

package com.seed.lee.model;

public class Person {

PersonUionPKID uionPKID = new PersonUionPKID();

private int age;

private String sex;

private String job;

public PersonUionPKID getUionPKID() { 
        return uionPKID; 
    }

public void setUionPKID(PersonUionPKID uionPKID) { 
        this.uionPKID = uionPKID; 
    }

public int getAge() { 
        return age; 
    }

public void setAge(int age) { 
        this.age = age; 
    }

public String getSex() { 
        return sex; 
    }

public void setSex(String sex) { 
        this.sex = sex; 
    }

public String getJob() { 
        return job; 
    }

public void setJob(String job) { 
        this.job = job; 
    }

}

3.配置hibernate配置文件,实例如下:

<?xml version="1.0"?> 
<!DOCTYPE hibernate-mapping PUBLIC 
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 
        "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="com.seed.lee.model">

<class name="Person" table="person">

<composite-id name="uionPKID" class="com.seed.lee.model.PersonUionPKID"> 
            <key-property name="secondName" /> 
            <key-property name="firstName" /> 
        </composite-id> 
        <property name="age" column="age" /> 
        <property name="sex" length="2" /> 
        <property name="job" length="50" /> 
    </class>

</hibernate-mapping>

4.不要忘记在hibernate配置文件中引用映射文件。

<mapping resource="com/seed/lee/model/Person.hbm.xml" />

具体参考hibernate3 API文档中的   “组件作为联合标识符(Components as composite identifiers)”说明。

时间: 2024-10-16 04:08:22

hibernate 联合主键生成机制(组合主键XML配置方式)的相关文章

Hibernate的increment主键生成机制带来的问题

最近给学校做的系统,总出现主键插入冲突的问题.主键是通过hibernate自动生成的,设置increment属性,总出现Duplicate entry的错误.搜到解决方案如下: 在网站运行在apache和tomcat的负载均衡之后,总是出现一些奇怪的问题.开始有一些Duplicate entry的错误,但没在意.          今天又看了程序运行的错误信息,发现几乎都是Duplicate entry错误,集中出现在insert数据库的时候,insert user,insert message

hibernate 一对多单向xml配置方式

实体类: public class Battery { private Integer id;//编号 private Set<BatteryVoltage> voltageList =new HashSet<>(); public class BatteryVoltage { private Integer id;//ID private Integer number;//编号 private Double voltage; //电压 private Integer equipm

Hibernate(5)—— 联合主键 、一对一关联关系映射(xml和注解) 和 领域驱动设计

俗话说,自己写的代码,6个月后也是别人的代码……复习!复习!复习!涉及的知识点总结如下: One to One 映射关系 一对一单向外键(XML/Annotation) 一对一双向外键关联(XML/Annotation) 联合主键 一对一单向外键联合主键(Xml/Annotation) 一对一组件关联(XML/Annotation) 理解组件 领域驱动设计——自动生成数据库脚本 一对一关系的小结 一些出错问题的总结 自动生成数据库脚本 一般在项目开发过程中,我们的习惯是先建好数据库和表,然后在进

Hibernate generator 主键生成策略

"assigned" 主键由外部程序负责生成,在   save()   之前指定一个. "hilo" 通过hi/lo   算法实现的主键生成机制,需要额外的数据库表或字段提供高位值来源. "seqhilo" 与hilo   类似,通过hi/lo   算法实现的主键生成机制,需要数据库中的   Sequence,适用于支持   Sequence   的数据库,如Oracle. "increment" 主键按数值顺序递增.此方式的

Hibernate各种主键生成策略2

先来看看主键映射的标签: <id   (1)name="propertyName"   (2)column="column_name" (3)type="typename">            (4)<generator class="generatorClass" />                 (5)<param name="param_name">para

Hibernate之:各种主键生成策略与配置详解

1.assigned 主键由外部程序负责生成,在 save() 之前必须指定一个.Hibernate不负责维护主键生成.与Hibernate和底层数据库都无关,可以跨数据库.在存储对象前,必须要使用主键的setter方法给主键赋值,至于这个值怎么生成,完全由自己决定,这种方法应该尽量避免. <id name="id" column="id"> <generator class="assigned" /> </id&g

[转]hibernate主键生成策略

1.assigned 主键由外部程序负责生成,在 save() 之前必须指定一个.Hibernate不负责维护主键生成.与Hibernate和底层数据库都无关,可以跨数据库.在存储对象前,必须要使用主键的setter方法给主键赋值,至于这个值怎么生成,完全由自己决定,这种方法应该尽量避免. <id name="id" column="id"> <generator class="assigned" /> </id&g

hibernate主键生成策略

引用:http://www.cnblogs.com/hoobey/p/5508992.html 1.assigned 主键由外部程序负责生成,在 save() 之前必须指定一个.Hibernate不负责维护主键生成.与Hibernate和底层数据库都无关,可以跨数据库.在存储对象前,必须要使用主键的setter方法给主键赋值,至于这个值怎么生成,完全由自己决定,这种方法应该尽量避免. <id name="id" column="id"> <gene

Hibernate各种主键生成策略与配置详解

1.assigned 主键由外部程序负责生成,在 save() 之前必须指定一个.Hibernate不负责维护主键生成.与Hibernate和底层数据库都无关,可以跨数据库.在存储对象前,必须要使用主键的setter方法给主键赋值,至于这个值怎么生成,完全由自己决定,这种方法应该尽量避免. <id name="id" column="id"> <generator class="assigned" /> </id&g