@NotFound解决关联外键数据不存在时抛出异常的问题
2015-06-02 23:46
429 查看
使用hibernate 注解配置实体类的关联关系,在many-to-one,one-to-one关联中,一边引用自另一边的属性,如果属性值为某某的数据在数据库不存在了,hibernate默认会抛出异常。解决此问题,加上如下注解就可以了:
@NotFound(action=NotFoundAction.IGNORE),意思是找不到引用的外键数据时忽略,NotFound默认是exception
下面贴出hibernate 注解的实例代码
@Entity
@Table(name = "ICT_COMPUTER_LOCATION")
public class IctComputerLocation {
private static final long serialVersionUID = 1L;
private Integer id;
/** IDC编号 */
private String idcNum;
private Integer ictBaseId;
/** IctBase实体类 */
private IctBase ictBase;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "ID")
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
@Column(name = "IDC_NUM")
public String getIdcNum() {
return idcNum;
}
public void setIdcNum(String idcNum) {
this.idcNum = idcNum;
}
@Column(name = "ICT_BASE_ID")
public Integer getIctBaseId() {
return ictBaseId;
}
public void setIctBaseId(Integer ictBaseId) {
this.ictBaseId = ictBaseId;
}
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "ICT_BASE_ID", referencedColumnName = "ID", unique = false, nullable = false, insertable = false, updatable = false)
@NotFound(action=NotFoundAction.IGNORE)
public IctBase getIctBase() {
return ictBase;
}
public void setIctBase(IctBase ictBase) {
this.ictBase = ictBase;
}
@NotFound(action=NotFoundAction.IGNORE),意思是找不到引用的外键数据时忽略,NotFound默认是exception
下面贴出hibernate 注解的实例代码
@Entity
@Table(name = "ICT_COMPUTER_LOCATION")
public class IctComputerLocation {
private static final long serialVersionUID = 1L;
private Integer id;
/** IDC编号 */
private String idcNum;
private Integer ictBaseId;
/** IctBase实体类 */
private IctBase ictBase;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "ID")
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
@Column(name = "IDC_NUM")
public String getIdcNum() {
return idcNum;
}
public void setIdcNum(String idcNum) {
this.idcNum = idcNum;
}
@Column(name = "ICT_BASE_ID")
public Integer getIctBaseId() {
return ictBaseId;
}
public void setIctBaseId(Integer ictBaseId) {
this.ictBaseId = ictBaseId;
}
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "ICT_BASE_ID", referencedColumnName = "ID", unique = false, nullable = false, insertable = false, updatable = false)
@NotFound(action=NotFoundAction.IGNORE)
public IctBase getIctBase() {
return ictBase;
}
public void setIctBase(IctBase ictBase) {
this.ictBase = ictBase;
}
相关文章推荐
- Part 72 to 81 Talking about Dictionary and List collection in C#
- 国嵌内核驱动进阶班-7-1(Ioctl设备控制)
- HTML5
- norflash与nandflash芯片内执行(XIP)
- java两个变量交换值不借助第三个变量所想
- [POJ 1328] Radar Installation
- Task 6.3 冲刺Two之站立会议2
- 实现文本的自动移动
- [POJ 2376] Cleaning Shifts
- http服务(一)――apache工作模式
- python impl模式
- 软件工程师薪福指南
- python中的map和reduce学习
- CUDA ---- Branch Divergence and Unrolling Loop
- Add and Search Word - Data structure design
- kyeremal-bzoj2038-[2009国家集训队]-小z的袜子(hose)-莫队算法
- JAVA生成UUID简介
- 做一个公益网站要花费多少钱
- 同步调用和异步调用同时存在导致的混乱
- [LeetCode] Minimum Path Sum