依然是学生和学生卡的关联,这次是一对一单项主键关联

student.cfg.xml:

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">


<hibernate-mapping package="cn.edu.hpu.model">
    <class name="Student" table="student" dynamic-update="true">
	<id name="id" column="id">
                <!-- 靠外键的关联来设置主键 class="foreign" -->
		<generator class="foreign">
                   <param name="property">student</param>
                </generator>   
	</id>  
        <property name="name"></property>
        <property name="age"></property>
    </class>
</hibernate-mapping>





(只改了这里)


StuIDCard.cfg.xml:


<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">


<hibernate-mapping>
    <class name="cn.edu.hpu.model.StuIDCard">
        <id name="id">
            <generator class="native"></generator>
        </id>


        <property name="num"/>
        <one-to-one name="student"></one-to-one>
    </class>
</hibernate-mapping>



生成的建表语句,StuIDCard里面也没有了student_id


create table StuIDCard (

         id integer not null auto_increment,

         num varchar(255),

         primary key (id)

     )



     create table student (

         id integer not null,

         name varchar(255) not null,

         age integer,

         primary key (id, name)

     )

 schema export complete




但是你会发现没有建立外键联系,这个时候就很危险,会产生id不一致的情况!




如何在xml配置文件中进行外键联系:


constrained="true"意思就是帮你加一个外键关联约束。

<one-to-one name="student" constrained="true"></one-to-one>




新的建表语句:



create table StuIDCard (

         id integer not null auto_increment,

         num varchar(255),

         primary key (id)

     )



     create table student (

         id integer not null,

         name varchar(255),

         age integer,

         primary key (id)

     )



     alter table StuIDCard 

         add index FKD1E159DFFB389035 (id), 

         add constraint FKD1E159DFFB389035 

         foreign key (id) 

         references student (id)

 schema export complete


可以看到,已经加了外键关联(StuIDCard的ID字段上有小钥匙的图标)