Hibernate 注解映射

本文深入探讨了Hibernate在处理一对一双向关联时的常见问题及解决方案,特别是在测试阶段,如何确保数据的有效关联。通过具体示例,解析了@OneToOne、@NotFound等注解的正确使用方法。

工作中遇到hibernate映射的一些问题,这里总结一下

(特别是测试时,许多数据并不能有效关联。所以@NotFound 很重要)

一,假设有2张表user,company

我们知道,一个用户属于一个公司。那么我们这么创建Model

//用户
public class User
{
private int id;
private String name;
private int companyid

//sub table
private Company company;

@Where(clause="IsValid=1")
@OneToOne(fetch= FetchType.EAGER,optional = true)
@NotFound(action= NotFoundAction.IGNORE)
@JoinColumn(name = "companyid", referencedColumnName = "companyid",insertable = false, updatable = false)
public Company getCompany() {
return company;
}
public void setCompany(Company company) {
this.company = company;
}
}


//公司
public class Company
{
private int companyid;
private int isValid; //是否有效
}

 


二 , 解释一下

@Where(clause="IsValid=1") 设定只查询IsValid=1的信息
@OneToOne(fetch= FetchType.EAGER,optional = true) FetchType.EAGER 及时加载,optional = true 是否必须有值
@NotFound(action= NotFoundAction.IGNORE) 忽略没有关联的外键
@JoinColumn(name = "inboundOrderUUID", referencedColumnName = "inboundOrderUUID",insertable = false, updatable = false)
name:本类的关联id referencedColumnName:关联项的id

PS:Dao使用@Query注解,也会查询到关联对象。

转载于:https://www.cnblogs.com/hanjun0612/p/10059157.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值