Hibernate深入浅出(十六)-----读深入浅出hibernate有感
数据关联:
一对一关联包括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;
}
}
对应的映射文件:
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 >
<! 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;
}
}
对应的映射文件:
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 >
<! 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表的主键。