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

前端之家收集整理的这篇文章主要介绍了【hibernate框架】一对一单向主键关联(XML实现)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

student.cfg.xml:

  1. <?xml version="1.0"?>
  2. <!DOCTYPE hibernate-mapping PUBLIC
  3. "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
  4. "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
  5.  
  6.  
  7. <hibernate-mapping package="cn.edu.hpu.model">
  8. <class name="Student" table="student" dynamic-update="true">
  9. <id name="id" column="id">
  10. <!-- 靠外键的关联来设置主键 class="foreign" -->
  11. <generator class="foreign">
  12. <param name="property">student</param>
  13. </generator>
  14. </id>
  15. <property name="name"></property>
  16. <property name="age"></property>
  17. </class>
  18. </hibernate-mapping>




(只改了这里)
StuIDCard.cfg.xml:
  1. <?xml version="1.0"?>
  2. <!DOCTYPE hibernate-mapping PUBLIC
  3. "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
  4. "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
  5.  
  6.  
  7. <hibernate-mapping>
  8. <class name="cn.edu.hpu.model.StuIDCard">
  9. <id name="id">
  10. <generator class="native"></generator>
  11. </id>
  12.  
  13.  
  14. <property name="num"/>
  15. <one-to-one name="student"></one-to-one>
  16. </class>
  17. </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,name varchar(255),primary key (id) ) alter table StuIDCard add index FKD1E159DFFB389035 (id),add constraint FKD1E159DFFB389035 foreign key (id) references student (id) schema export complete 可以看到,已经加了外键关联(StuIDCard的ID字段上有小钥匙的图标)

猜你在找的XML相关文章