hibernate详解(七)基于外键映射的一对一关联关系

直接上代码:
sql语句:


/* 基于外键的映射 */
CREATE TABLE t_person_fk
 (
    id NUMBER(10) PRIMARY KEY,
    name VARCHAR2(20) NOT NULL,
    gender VARCHAR2(10),
    age NUMBER(3) CHECK(age BETWEEN 1 AND 100)
 );

CREATE TABLE t_passport_fk
 (
    id NUMBER(10) PRIMARY KEY,
    bh VARCHAR2(20) NOT NULL UNIQUE,
    person_id NUMBER(10) REFERENCES t_person_fk(id) UNIQUE
 );
 
 CREATE SEQUENCE t_person_fk_seq
 START WITH 1
 INCREMENT BY 1;
 
 CREATE SEQUENCE t_passport_fk_seq
 START WITH 1
 INCREMENT BY 1;

Person.java

package com.iotek.basic.association.one2one.pojo;

import java.io.Serializable;

public class Person implements Serializable{

    private static final long serialVersionUID = -5614535607156334069L;
    private Long id;
    private String name;
    private String gender;
    private Integer age;
    private Passport passport;
    
    public Person() {}

    public Person(Long id, String name, String gender, Integer age, Passport passport) {
        super();
        this.id = id;
        this.name = name;
        this.gender = gender;
        this.age = age;
        this.passport = passport;
    }

    public Long getId() {
        return id;
    }

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

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getGender() {
        return gender;
    }

    public void setGender(String gender) {
        this.gender = gender;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public Passport getPassport() {
        return passport;
    }

    public void setPassport(Passport passport) {
        this.passport = passport;
    }

    public static long getSerialversionuid() {
        return serialVersionUID;
    }

    @Override
    public String toString() {
        return "Person [id=" + id + ", name=" + name + ", gender=" + gender + ", age=" + age + ", passport=" + passport
                + "]";
    }

}

Passport.java

package com.iotek.basic.association.one2one.pojo;

import java.io.Serializable;

public class Passport implements Serializable{
    
    private static final long serialVersionUID = -2402152980390377315L;
    private Long id;
    private String bh;
    private Person person;
    
    public Passport() {}

    public Passport(Long id, String bh, Person person) {
        super();
        this.id = id;
        this.bh = bh;
        this.person = person;
    }

    public Long getId() {
        return id;
    }

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

    public String getBh() {
        return bh;
    }

    public void setBh(String bh) {
        this.bh = bh;
    }

    public Person getPerson() {
        return person;
    }

    public void setPerson(Person person) {
        this.person = person;
    }
    
    public static long getSerialversionuid() {
        return serialVersionUID;
    }
    
    @Override
    public String toString() {
        return "Passport [id=" + id + ", bh=" + bh + "]";
    }
    
    
}

映射文件:
Person_FK.hbm.xml

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

<hibernate-mapping package="com.iotek.basic.association.one2one.pojo">
    <class name="Person" table="T_PERSON_FK">
        <id name="id" column="ID" type="long">
            <generator class="sequence">
                <param name="sequence">t_person_fk_seq</param>
            </generator>
        </id>
        
        <property name="name" type="string" column="NAME"/>
        <property name="age" type="integer" column="AGE"/>
        <property name="gender" type="string" column="GENDER"/>
        <one-to-one name="passport" class="Passport" property-ref="person" cascade="all"/>
    </class>
</hibernate-mapping>

Passport_FK.hbm.xml

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

<hibernate-mapping package="com.iotek.basic.association.one2one.pojo">
    <class name="Passport" table="T_PASSPORT_FK">
        <id name="id" column="ID" type="long">
            <generator class="sequence">
                <param name="sequence">t_passport_fk_seq</param>
            </generator>
        </id>
        
        <property name="bh" type="string" column="BH"/>
        <many-to-one name="person" class="Person" column="PERSON_ID" unique="true"/>
    </class>
</hibernate-mapping>

测试类:
One2OneTest.java

package com.iotek.basic.association.one2one.pojo;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;

import com.iotek.basic.common.HibernateSessionFactory;

public class One2OneTest {

    public static void main(String[] args) {
        Person person = new Person();
        person.setName("zhangsan");
        person.setAge(18);
        person.setGender("male");
        
        Passport passport = new Passport();
        passport.setBh("G10562343");
        
        person.setPassport(passport);
        passport.setPerson(person);
        
        Session session = HibernateSessionFactory.getSession();
        Transaction transaction = null;
        
        try {
            transaction = session.beginTransaction();
            // 增
            // session.save(person);
            // 查
            Person person2 = session.get(Person.class, 21L);
            // 改
            // person2.setName("zhangsanfeng");
            // person2.setAge(22);
            // person2.getPassport().setBh("G12211221");
            // session.update(person2);
            // 删
            session.delete(person2);
            transaction.commit();
        } catch (Exception e) {
            e.printStackTrace();
            transaction.rollback();
        }
    }

}

这里要注意的是如何分别在表的层面以及类的层面配置一对一的关联关系。以及双向的关联关系。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,039评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,426评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,417评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,868评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,892评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,692评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,416评论 3 419
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,326评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,782评论 1 316
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,957评论 3 337
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,102评论 1 350
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,790评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,442评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,996评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,113评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,332评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,044评论 2 355

推荐阅读更多精彩内容