通常,外键约束引用主键。外键约束是一个完整性规则,它保证被引用的表有一行所包含的键值与引用表和给定行中的键值相匹配。
遗留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>
若不按上述方法写配置文件,则可能会出现非主属性做外键属性名而值是主键值的情况