如上图所示:一个学生有一个学生证号,一个学生证号对应一名学生。在Hibernate中怎么用Annotation来实现呢?
学生类,主键是id;学生证的主键也是Id;
Student.java

package edu.xaut.hibernate;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.OneToOne;

@Entity
public class Student {
    private int id;
    private String name;
    private String gender;
    private int age;
    private StuIdCard stuIdCard;

@Id
    @GeneratedValue
    public int getId() {
        return id;
    }

@Column(name = "name", length = 20)
    public String getName() {
        return name;
    }

@Column(name = "gender", length = 6)
    public String getGender() {
        return gender;
    }

public int getAge() {
        return age;
    }

@OneToOne
    @JoinColumn(name = "StuIdCard")
    public StuIdCard getStuIdCard() {
        return stuIdCard;
    }

public void setId(int id) {
        this.id = id;
    }

public void setName(String name) {
        this.name = name;
    }
   
    public void setGender(String gender) {
        this.gender = gender;
    }
   
    public void setAge(int age) {
        this.age = age;
    }

public void setStuIdCard(StuIdCard stuIdCard) {
        this.stuIdCard = stuIdCard;
    }
}

package edu.xaut.hibernate;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.OneToOne;

@Entity
public class StuIdCard {
    private int id;
    private String num;
    private Student student;

@Id
    @GeneratedValue
    public int getId() {
        return id;
    }

public void setId(int id) {
        this.id = id;
    }

@Column(length = 20)
    public String getNum() {
        return num;
    }

public void setNum(String num) {
        this.num = num;
    }

@OneToOne(mappedBy="stuIdCard")
    public Student getStudent() {
        return student;
    }

public void setStudent(Student student) {
        this.student = student;
    }
}

导出的SQL语句如下:
create table StuIdCard (
        id integer not null auto_increment,
        num varchar(20),
        primary key (id)
    )

create table Student (
        id integer not null auto_increment,
        age integer not null,
        gender varchar(6),
        name varchar(20),
        StuIdCard integer,
        primary key (id)
    )

alter table Student
        add index FKF3371A1BFDFA0D4 (StuIdCard),
        add constraint FKF3371A1BFDFA0D4
        foreign key (StuIdCard)
        references StuIdCard (id)

测试代码如下:
package edu.xaut.hibernate;

import org.hibernate.Session;
import org.hibernate.cfg.*;
import org.hibernate.tool.hbm2ddl.SchemaExport;
import org.junit.Test;

import edu.xaut.wuqiang.hibernate.util.HibernateUtil;

public class HibernateORMappingTest {

@Test
    public void testStudentSave() {
        Session session = HibernateUtil.getSessionFactory().getCurrentSession();
        session.beginTransaction();
        StuIdCard stuIdCard = new StuIdCard();
        stuIdCard.setNum("1008120672");
        session.save(stuIdCard);
       
        Student stu = new Student();
        stu.setName("Lily");
        stu.setGender("Female");
        stu.setAge(22);
        stu.setStuIdCard(stuIdCard);
        session.save(stu);

session.getTransaction().commit();
        HibernateUtil.getSessionFactory().close();
    }

@Test
    public void testQueryStuInfo() {
        Session session = HibernateUtil.getSessionFactory().getCurrentSession();
        session.beginTransaction();
        StuIdCard stuIdCard = (StuIdCard) session.get(StuIdCard.class, 1);
        System.out.println(stuIdCard.getNum());
        System.out.println(stuIdCard.getStudent().getName() + "\t"
                + stuIdCard.getNum() + "\t"
                + stuIdCard.getStudent().getGender() + "\t"
                + stuIdCard.getStudent().getAge());
        session.getTransaction().commit();
        HibernateUtil.getSessionFactory().close();
    }

@Test
    public void testSchemaExport() {
        new SchemaExport(new AnnotationConfiguration().configure()).create(
                true, true);
    }   
}

运行结果如下:
    select
        stuidcard0_.id as id0_1_,
        stuidcard0_.num as num0_1_,
        student1_.id as id1_0_,
        student1_.age as age1_0_,
        student1_.gender as gender1_0_,
        student1_.name as name1_0_,
        student1_.StuIdCard as StuIdCard1_0_
    from
        StuIdCard stuidcard0_
    left outer join
        Student student1_
            on stuidcard0_.id=student1_.StuIdCard
    where
        stuidcard0_.id=?
1008120672
Lily    1008120672    Female    22

http://blog.sina.com.cn/s/blog_4979ec3e010174nx.html

Hibernate一对一外键双向关联(Annotation配置)的更多相关文章

  1. hibernate一对一外键双向关联

    关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...

  2. hibernate一对一外键单向关联

    关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...

  3. hibernate一对一主键双向关联

    关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...

  4. hibernate一对一主键单向关联

    关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...

  5. Hibernate一对一外键映射

    Hibernate 一对一外键映射                    ------------------------------                            ----- ...

  6. Hibernate,一对一外键单向 记录。Timestamp 的一个坑。

    首先是2张表 表A: 表B: 其中表B中的FormBaseId对应表A中的SubjectID. 数据库中没有设置外键关系. 下面是2个对应的实体 package questionnaire.model ...

  7. Hibernate,关系映射的多对一单向关联、多对一双向关联、一对一主键关联、一对一外键关联、多对多关系关联

    2018-11-10  22:27:02开始写 下图内容ORM.Hibernate介绍.hibername.cfg.xml结构: 下图内容hibernate映射文件结构介绍 下图内容hibernate ...

  8. hibernate之关于一对一单向,双向关联映射

    [hibernate]之关于一对一单向,双向关联映射 首先我们来看,Hibernate官方对于一对一单向关联的解释: 基于外键关联的单向一对一关联和单向多对一关联差点儿是一样的. 唯一的不同就是单向一 ...

  9. ORM框架Hibernate (四) 一对一单向、双向关联映射

    简介 在上一篇博客说了一下多对一映射,这里再说一下一对一关联映射,这种例子在生活中很常见,比如一个人的信息和他的身份证是一对一.又如一夫一妻制等等. 记得在Java编程思想上第一句话是“一切皆对象”, ...

随机推荐

  1. DevWebForm控件,触发用客户端事件

    ClientInstanceName+".Raise"+"事件名", 例如: ClientInstanceName.RaiseValueChanged();

  2. java sdk与jdk区别

    SDK是Software Development Kit的缩写,中文意思是"软件开发工具包".这是一个覆盖面相当广泛的名词,可以这么说:辅助开发某一类软件的相关文档.范例和工具的集 ...

  3. HDU 1394 Minimum Inversion Number(最小逆序数 线段树)

    Minimum Inversion Number [题目链接]Minimum Inversion Number [题目类型]最小逆序数 线段树 &题意: 求一个数列经过n次变换得到的数列其中的 ...

  4. 【转】EXCEL不显示科学计数法

    源地址:http://jingyan.baidu.com/article/e4d08ffdcc304e0fd3f60d69.html 2法无效,不知道为何

  5. [SQL]复制数据库某一个表到另一个数据库中

    SQL:复制数据库某一个表到另一个数据库中 SELECT * INTO 表1 FROM 表2 --复制表2如果只复制结构而不复制内容或只复制某一列只要加WHERE条件就好了 例子:SELECT * I ...

  6. 第一周:设计一个简易ATM取款机简易程序(2)

    1.了解用户对ATM取款机功能需求如下: 2.新建一个login函数使用for循环方法和if选择方法编写登陆界面用来及设置ATM内用户的金额和取款机内的金额: 3.使用新建函数方法及if选择方法编写登 ...

  7. [DFNews] Touch ID不是神话,指模依旧能搞定。

    扫描制作翻模,使用含石墨硅胶压膜,前者复制指纹纹路,后者欺骗活体检测.

  8. springmvc 接受特殊类型字段的处理方法

    springmvc接受前台传入的数据时如果该字段类型无法被封装(如Date),则会出现400 Bad Request错误,解决方法如下. 1.在需要处理的字段前加上注解: @DateTimeForma ...

  9. tomcat6配置jndi连接数据库的方式

    eworkflow工作流+eform表单+ebiao报表集成在一起,用tomcat6发布,并用jndi连接数据库,数据库是sqlserver2005,配置如下: 1.在tomcat6\conf\con ...

  10. HEVC学习之二CTU, CU, CTB, CB, PB, TB

    在H264标准中,编码层的核心是宏块,一个宏块大小为16X16,包含一个16X16的亮度块,以及对于常用的4:2:0采样格式来说还包含两个8X8的色度块.相对应的在HEVC中类似的结构为编码树单元(C ...