【hibernate框架】一对一单向主键关联(XML实现)

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

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配置文件中进行外键联系:
<one-to-one name="student" constrained="true"></one-to-one>
constrained="true"意思就是帮你加一个外键关联约束。


新的建表语句:
 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字段上有小钥匙的图标)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

光仔December

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值