数据关联:
一对一关联包括2种类型:1、主键关联2、唯一外键关联
一对一的主键关联形式,即2张关联表通过主键形成一对一映射关系。
<one-to-one>节点定义了类与类之间的关系。
package com.wyq.demo.common.reference.onetoone.primekey;
import java.io.Serializable;
/**
* @author 作者
* @version 创建时间:2008-11-28 上午09:39:56
* 类说明 Hibernate中的唯一外键关联由"many-to-one"节点定义
* 使用外键来完成一对一,骑士就是限制多对一关系中,多的一方只能有一个参考至一的一方,也就是多对以关系
* 的一个特例,这可以在映射文件中使用<many-to-one>标签时,加上"unique"属性来设定
*/
public class TUser implements Serializable {
private Integer id;
private Integer age;
private String name;
private TGroup group;
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
public TGroup getGroup() {
return group;
}
public void setGroup(TGroup group) {
this.group = group;
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
对应的映射文件:
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!--
Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
<class name="com.wyq.demo.common.reference.onetoone.TUser" table="t_user" catalog="sample">
<id name="id" type="java.lang.Integer">
<column name="id" />
<generator class="native" />
</id>
<property name="name" type="java.lang.String">
<column name="name"></column>
</property>
<property name="age" type="java.lang.Integer">
<column name="age"></column>
</property>
<one-to-one name="passport" class="com.wyq.demo.common.reference.onetoone.TPassport" cascade="all" outer-join="true"></one-to-one>
</class>
</hibernate-mapping>
级联(cscade)在Hibernate映射关系中是个非常重要的概念。它指的是当主控方执行操作时,关联对象(被动方)是否同步执行同一操作。如对主控对象调用save-update或delete方法时,是否同时对关联对象(被动方)进行save-update或delete
package com.wyq.demo.common.reference.onetoone.foreignkey;
import java.io.Serializable;
/**
* @author 作者
* @version 创建时间:2008-11-28 上午09:14:10
* 类说明 由于采用了主键关联方式,那么通过主键关联的2张表,其关联记录的主键值须保持
* 同步。这也就是说,我们只须为一张表设定主键生成器,而另一张表的主键与之共享
* 相同的主键值。我们可以通过"foreign"类型的主键生成器与外键共享主键值。
* 同时,one-to-one节点的constrained属性必须设定为"true",以告知hibernate
* 当前表主键上存在一个约束。
* 在TPassport的id主键上,使用foreign标示与外键共享主键,也就是与User实体共享主键,而
* constrained设定为true,表示约束TPassport的主键必须与user中对应资料的主键相同
*/
public class TPassport implements Serializable {
private Integer id;
private String serial;
private Integer expiry;
private TUser user;
public Integer getExpiry() {
return expiry;
}
public void setExpiry(Integer expiry) {
this.expiry = expiry;
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getSerial() {
return serial;
}
public void setSerial(String serial) {
this.serial = serial;
}
public TUser getUser() {
return user;
}
public void setUser(TUser user) {
this.user = user;
}
}
对应的映射文件:
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!--
Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
<class name="com.wyq.demo.common.reference.onetoone.TPassport" table="t_passport" catalog="sample">
<id name="id" column="id">
<!-- 定义根据user表的主键生成 -->
<generator class="foreign">
<param name="property">user</param>
</generator>
</id>
<!-- 定义约束constrained -->
<one-to-one name="user" class="com.wyq.demo.common.reference.onetoone.TUser" constrained="true"></one-to-one>
<property name="serial" type="java.lang.String" column="serial"></property>
<property name="expiry" type="java.lang.Integer" column="expiry"></property>
</class>
</hibernate-mapping>
由于采用了主键关联方式,那么通过主键关联的2张表,其关联记录的主键值须保持同步。这也就意味着,我们只需要为一张表设定主键生成器,而另一张表的主键与之共享相同的主键值。
在Hibernate中,我们可以通过"foreign"类型的主键生成器与外键共享主键值。同时,one-to-one节点的constrained属性设定为"true",以告知Hibernate当前表主键上存在一个约束:"T_Passport"表引用了T_User表的主键。
posted on 2009-11-04 10:01
王永庆 阅读(173)
评论(0) 编辑 收藏 所属分类:
HIBERNATE