posts - 66,  comments - 11,  trackbacks - 0
    对于任何关联操作,首先操作的是主体,然后查看主体的映射文件是否关联其他对象,如果关联,查看关联方式,并进行操作。  
 name: 属性名。

 column (可选): 表字段名。
 
class : 关联的类的名字。

cascade(级联) (可选): 指明哪些操作会从父对象级联到关联的对象。

property-ref: (可选) 指定关联类的一个属性,这个属性将会和本外键相对应。 如果没有指定,会使用对方关联类的主键。

unique (可选): 使用DDL为外键字段生成一个唯一约束。此外, 这也可以用作property-ref的目标属性。这使关联同时具有 一对一的效果。

not-null (可选): 使用DDL为外键字段生成一个非空约束。

Hibernate唯一外键关联的一对一关系只是多对以关系的一个特例:

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.primekey.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>
        
<many-to-one name="group" class="com.wyq.demo.common.reference.onetoone.primekey.TGroup" column="group_id" unique="true"></many-to-one>
    
</class>
</hibernate-mapping>
一端的关联类:
package com.wyq.demo.common.reference.onetoone.primekey;

import java.io.Serializable;

/** 
 * 
@author 作者 
 * 
@version 创建时间:2008-11-28 上午09:40:21 
 * 类说明 如果要实现双向的一对一关系,则需要对TGroup进行修改,为其增加一个TUser类
 *         完成双向一对一,要在<one-to-one>中,property-ref告诉hibernate,查询出user并将其参考至group
 
*/
public class TGroup implements Serializable {
    
private Integer id;
    
private String name;
    
private TUser user;
    
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;
    }
    
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.primekey.TGroup" table="t_group" 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>
        
<one-to-one name="user" class="com.wyq.demo.common.reference.onetoone.primekey.TUser" property-ref="group"></one-to-one>
    
</class>
</hibernate-mapping>

posted on 2009-11-04 11:05 王永庆 阅读(201) 评论(0)  编辑  收藏 所属分类: HIBERNATE

只有注册用户登录后才能发表评论。


网站导航:
 
<2009年11月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
293012345

常用链接

留言簿(1)

随笔分类

随笔档案

关注blogs

搜索

  •  

最新评论

阅读排行榜

评论排行榜