Hibernate非主属性做外键

通常,外键约束引用主键。外键约束是一个完整性规则,它保证被引用的表有一行所包含的键值与引用表和给定行中的键值相匹配。

遗留schema有时候会有不遵循简单的"外键引用主键"规则的外键约束。有时候外键引用非主键,一个简单的唯一列,一个自然的非主键。注意,被外键引用的非主键列必须用:unique="true"约束。

hibernate映射中你会遇到property-ref属性,它用来告诉hibernate”这是具名属性的一个镜像" ,property-ref还要求目标属性是唯一的,所以被外键引用的非主键列必须用:unique="true"约束。


<?xml version="1.0" encoding="UTF-8"?>      
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN"      
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">      
<hibernate-mapping package="pojo">      
    <class name="User" table="A_USER" dynamic-insert="true" dynamic-update="true">  
        <id name="id" column="ID" type="string">  
            <generator class="uuid.hex"/>  
        </id>  
        <!-- 注意这里加了unique="true",将在被外键引用的非主键列 -->  
        <property name="name" column="NAME" type="string" unique="true"/>  
        <property name="password" column="PASSWORD" type="string"/>  
        <property name="age" type="integer" column="AGE"/>    
        <set name="itemSet" inverse="true" cascade="save-update">  
            <!-- 注意这里使用了property-ref="name" -->  
            <key column="NAME" property-ref="name" not-null="true"/>  
            <one-to-many class="Item"/>  
        </set>  
    </class>     
</hibernate-mapping> 

<?xml version="1.0" encoding="UTF-8"?>      
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN"      
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">      
<hibernate-mapping package="pojo">      
    <class name="Item" table="A_ITEM" dynamic-insert="true" dynamic-update="true">  
        <id name="id" column="ID" type="string">  
            <generator class="uuid.hex"/>  
        </id>  
        <property name="name" column="ITEMNAME" type="string"/>  
        <property name="desc" column="DESCRIPTION" type="string"/>  
        <property name="price" column="PRICE" type="integer"/>  
        <!-- 注意这里使用了property-ref="name" -->  
        <many-to-one name="user" class="User" column="NAME" property-ref="name"/>  
    </class>     
</hibernate-mapping>  

若不按上述方法写配置文件,则可能会出现非主属性做外键属性名而值是主键值的情况

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值