Hibernate关联关系(3)

一对一关联

 

根据各种教科书的例子,一对一关联可通过两种方式实现,通过主键关联和通过外键关联,这里我只介绍一下通过外键关联。

在做一个例子,我在上面的程序中有一个User表,这里我在做一个IDCARD表,表里的内容设置了user的一些具体信息,他们是一对一的关系。

 

IDCARD表的SQL

CREATE TABLE `idcard` (

  `crd_id` int(11) NOT NULL auto_increment,

  `crd_no` char(11) NOT NULL default 0,

  `crd_eml` char(20) default NULL,

  `usr_id` int(11)NOT NULL default 0,

  PRIMARY KEY  (`crd_id`)

) ENGINE=InnoDB DEFAULT CHARSET=UTF8;

 

IdCard类为:

public class IdCard {

   

    private int id;

    private String cardNo;

    private String email;   

    private UserInfo user;

 

这里的一对一关联关系可以看成是一对多的一个特殊形式,可能也能猜到,就是在多的一端设置其外键唯一就可以了,即在节点<many-to-one>里面价格属性,unique="true"

IdCard映射文件为:

<?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>

   <class name="xiaojin.hibernate.entity.Message" table="MESSAGE">

      <id name="msgId" type="int" column="msg_id">

         <generator class="native"/>

      </id>

      <property name="ttl" column="msg_ttl" type="string" not-null="true"/>

      <property name="desc" column="msg_desc" type="string" not-null="true"/>

      <property name="date" column="msg_date" type="string" />

      <many-to-one name="user" class="xiaojin.hibernate.entity.UserInfo" column="usr_id" cascade="none"></many-to-one>

   </class>

</hibernate-mapping>

 

在一的一段的映射文件里也就是User里面再上一个<one-to-one>节点:

<one-to-one name="idCard" class="xiaojin.hibernate.entity.IdCard" cascade="all" property-ref="user" />

property-ref="user" 指定关联对象的属性名。

 

测试方法:

    public static void saveUserAndIdCard(){

        UserInfo user= new UserInfo();

        user.setName("xiaojin1");

        user.setPassword("xiaojin");

       

        IdCard idCard = new IdCard();

       

        idCard.setCardNo("12121212");

        idCard.setEmail("email");

        idCard.setUser(user);

       

        user.setIdCard(idCard);

       

        save(user);

        System.out.println("Save over ");

}

你可能感兴趣的:(sql,Hibernate,.net,xml)