文档章节

hibernate中OneToOne的级联保存

z_jordon
 z_jordon
发布于 2015/02/03 09:32
字数 719
阅读 62
收藏 0

两张表的关系如下:

对应的实体

package com.jason.logistics.entity.member;


import com.jason.logistics.entity.BaseEntity;
import com.jason.logistics.entity.express.ExprDelCom;

import java.util.Date;

import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.OneToOne;
import javax.persistence.Table;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;
import javax.persistence.Transient;

/**
 * MemberExpress.
 */
@Entity
@Table(name="logistics_member_express"
)
public class MemberExpress extends BaseEntity {

     private String userName;
     private String password;
     private String fullName;
     private String gender;
     private Long msisdn;
     private Date dateOfBirth;
     private String address;
     private Short userType;
     private String photo;
     private String nickName;
     private Short age;
     private String idCard;
    
     private ExprDelCom exprDelCom;//所属快递公司
     private ExpressUser expressUser;
    
    @Column(name="user_name", length=64)
    public String getUserName() {
        return this.userName;
    }
    
    public void setUserName(String userName) {
        this.userName = userName;
    }
    
    
    
    @Column(name="password", length=32)
    public String getPassword() {
        return this.password;
    }
    
    public void setPassword(String password) {
        this.password = password;
    }
    
    
    
    @Column(name="full_name", length=64)
    public String getFullName() {
        return this.fullName;
    }
    
    public void setFullName(String fullName) {
        this.fullName = fullName;
    }
    
    
    
    @Column(name="gender", length=8)
    public String getGender() {
        return this.gender;
    }
    
    public void setGender(String gender) {
        this.gender = gender;
    }
    
    
    
    @Column(name="msisdn", precision=11, scale=0)
    public Long getMsisdn() {
        return this.msisdn;
    }
    
    public void setMsisdn(Long msisdn) {
        this.msisdn = msisdn;
    }
    
    
    @Temporal(TemporalType.TIMESTAMP)
    @Column(name="date_of_birth", length=19)
    public Date getDateOfBirth() {
        return this.dateOfBirth;
    }
    
    public void setDateOfBirth(Date dateOfBirth) {
        this.dateOfBirth = dateOfBirth;
    }
    
    
    
    @Column(name="address", length=128)
    public String getAddress() {
        return this.address;
    }
    
    public void setAddress(String address) {
        this.address = address;
    }
    
    @OneToOne(fetch = FetchType.LAZY)
	@JoinColumn(name="expr_del_com_id",nullable=true, referencedColumnName="id", unique=true, updatable=true)
	public ExprDelCom getExprDelCom() {
		return exprDelCom;
	}

	public void setExprDelCom(ExprDelCom exprDelCom) {
		this.exprDelCom = exprDelCom;
	}
    
    
    
    @Column(name="user_type", precision=1, scale=0)
    public Short getUserType() {
        return this.userType;
    }
    
    public void setUserType(Short userType) {
        this.userType = userType;
    }
    
    
    
    @Column(name="photo", length=128)
    public String getPhoto() {
        return this.photo;
    }
    
    public void setPhoto(String photo) {
        this.photo = photo;
    }
    
    
    
    @Column(name="nick_name", length=64)
    public String getNickName() {
        return this.nickName;
    }
    
    public void setNickName(String nickName) {
        this.nickName = nickName;
    }
    
    
    
    @Column(name="age", precision=3, scale=0)
    public Short getAge() {
        return this.age;
    }
    
    public void setAge(Short age) {
        this.age = age;
    }
    
    
    
    @Column(name="id_card", length=18)
    public String getIdCard() {
        return this.idCard;
    }
    
    public void setIdCard(String idCard) {
        this.idCard = idCard;
    }
    
    //@OneToOne(cascade={CascadeType.MERGE,CascadeType.REMOVE,CascadeType.REFRESH,CascadeType.PERSIST})
    @OneToOne(cascade={CascadeType.ALL})
    @JoinColumn(name="express_user_id", referencedColumnName="id", unique=true, nullable=true, updatable=true)
	public ExpressUser getExpressUser() {
		return expressUser;
	}

	public void setExpressUser(ExpressUser expressUser) {
		this.expressUser = expressUser;
	}

	@Override
	@Transient
	public void onSave() {
	
		// TODO Auto-generated method stub
		
	}

	@Override
	@Transient
	public void onUpdate() {
		
		// TODO Auto-generated method stub
		
	}
}
package com.jason.logistics.entity.member;


import com.jason.logistics.entity.BaseEntity;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Table;
import javax.persistence.Transient;

/**
 * ExpressUser.
 */
@Entity
@Table(name="logistics_express_user"
)
public class ExpressUser extends BaseEntity {

     private String kuaidiNumber;
     private String sincerity;
     private String deliverGoods;
     private Short goodRate;
     private String companyName;


   
    
    
    @Column(name="kuaidi_number", length=64)
    public String getKuaidiNumber() {
        return this.kuaidiNumber;
    }
    
    public void setKuaidiNumber(String kuaidiNumber) {
        this.kuaidiNumber = kuaidiNumber;
    }
    
    
    
    @Column(name="sincerity", length=32)
    public String getSincerity() {
        return this.sincerity;
    }
    
    public void setSincerity(String sincerity) {
        this.sincerity = sincerity;
    }
    
    
    
    @Column(name="deliver_goods", length=2560)
    public String getDeliverGoods() {
        return this.deliverGoods;
    }
    
    public void setDeliverGoods(String deliverGoods) {
        this.deliverGoods = deliverGoods;
    }
    
    
    
    @Column(name="good_rate", precision=3, scale=0)
    public Short getGoodRate() {
        return this.goodRate;
    }
    
    public void setGoodRate(Short goodRate) {
        this.goodRate = goodRate;
    }
    
    
    
    @Column(name="company_name", length=64)
    public String getCompanyName() {
        return this.companyName;
    }
    
    public void setCompanyName(String companyName) {
        this.companyName = companyName;
    }
    
	
	@Override
	@Transient
	public void onSave() {
	
		// TODO Auto-generated method stub
		
	}

	@Override
	@Transient
	public void onUpdate() {
		
		// TODO Auto-generated method stub
		
	}
}

其中两个实体的对应关系如下:

 //@OneToOne(cascade={CascadeType.MERGE,CascadeType.REMOVE,CascadeType.REFRESH,CascadeType.PERSIST})
    @OneToOne(cascade={CascadeType.ALL})
    @JoinColumn(name="express_user_id", referencedColumnName="id", unique=true, nullable=true, updatable=true)
	public ExpressUser getExpressUser() {
		return expressUser;
	}

经测试发现,只有在设置

cascade={CascadeType.ALL}

的情况下才能在新增MemberExpress情况下一起新增ExpressUser(如果ExpressUser的id为null),其它情况如设置

@OneToOne(cascade={CascadeType.MERGE,CascadeType.REMOVE,CascadeType.REFRESH,CascadeType.PERSIST})

会报以下异常:

ERROR [com.opensymphony.xwork2.interceptor.ExceptionMappingInterceptor] - object references an unsaved transient instance - save the transient instance before flushing: com.jason.logistics.entity.member.ExpressUser; nested exception is org.hibernate.TransientObjectException: object references an unsaved transient instance - save the transient instance before flushing: com.jason.logistics.entity.member.ExpressUser
org.springframework.dao.InvalidDataAccessApiUsageException: object references an unsaved transient instance - save the transient instance before flushing: com.jason.logistics.entity.member.ExpressUser; nested exception is org.hibernate.TransientObjectException: object references an unsaved transient instance - save the transient instance before flushing: com.jason.logistics.entity.member.ExpressUser


© 著作权归作者所有

共有 人打赏支持
z_jordon
粉丝 36
博文 251
码字总数 78212
作品 0
厦门
技术主管
私信 提问
hibernate关联关系的整理

hibernate关联关系的整理 1、关联关系映射的步骤 1.1关联关系的搭建 ---建表 ---建实体 1.2映射关联关系 1.3使用测试 2、映射关联关系 1:1 双向 单向 主表方: //关系属性 主表方: //mapped...

优惠券发放
2018/04/18
0
0
纠结了很久的hiberante问题

hiberante的OneToOne级联问题,hiberante用的很爽、非常爽,但是唯一让我不爽的就是OneToOne的级联问题,每当我查一个对象的时候,与之相关联的(OneToOne关联关系)全部会查出来,然后看见C...

GITTODO
2014/11/28
133
5
Hibernate学习4--Hibernte的映射关系(一)

Hibernate中最绕的部分莫过于各种映射了,其实大致上就3种,一对一映射onetoone,一对多映射onetomany,多对一映射manytoone,多对多映射manytomany。一对一映射又有一对一主键映射和唯一外键...

王小明123
2014/04/18
0
0
Hibernate的annotation

@Controller控制器 @Service @Conponent 组件 @Repository Dao访问层 @Entity 实体 @Table 实体mapping表 @Column 属性mapping列 ----> 不需要Mapping的时候用@Transient @Id mapping主键属性......

geeksun
2012/05/11
0
0
Hibernate 注解简单总结

1.标准注解 a) @Entity 映射一个实体类 @Table指定关联的表 b) @Id 映射OID c) @GeneratedValue 指定OID的生成策略 @GeneratedValue的属性strategy指定生成策略, IDENTITY(自增长方式,如m...

凡尘里的一根葱
2015/09/24
16
0

没有更多内容

加载失败,请刷新页面

加载更多

OSChina 周三乱弹 —— 哽住

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @蓝瞳 :分享高橋広樹的单曲《銀河沿線'05<Vo>》:一直暗恋却无法表白的女孩在电车上疲倦不堪累得靠在他的肩上,播磨拳儿终于忍不住流下了眼泪...

小小编辑
40分钟前
79
5
shell输入内容时不显示内容

简介 大家都知道当我们ssh登录linux服务器的时候输入密码密码是不显示在屏幕上的,同样在我们写shell脚本的时候在获取用户密码的时候,有时候也希望不显示密码,这个是怎么做的呢 实例脚本 ...

bboysoulcn
今天
3
0
第11章 多线程

程序、进程、线程 程序(program)是为完成特定任务、用某种语言编写的一组指令的集合。即指一段静态的代码,静态对象。 **进程(process)**是程序的一次执行过程或是正在运行的一个程序。动...

流小文
今天
6
0
SpringBoot引入第三方jar包或本地jar包的处理方式

在开发过程中有时会用到maven仓库里没有的jar包或者本地的jar包,这时没办法通过pom直接引入,那么该怎么解决呢 一般有两种方法 - 第一种是将本地jar包安装在本地maven库 - 第二种是将本地j...

独钓渔
今天
2
0
五、MyBatis缓存

一、MyBatis缓存介绍 缓存的使用可以明显的加快访问数据速度,提升程序处理性能,生活和工作中,使用缓存的地方很多。在开发过程中,从前端-->后端-->数据库等都涉及到缓存。MyBatis作为数据...

yangjianzhou
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部