工作中遇到的问题--Hibernate一对多保存简化Service层代码
在创建一方的entity是添加一个增加多方的方法:
package com.sim.mfg.data.domain;
import java.io.Serializable;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.EnumType;
import javax.persistence.Enumerated;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.MapKeyColumn;
import javax.persistence.MapKeyEnumerated;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import org.hibernate.annotations.Where;
import com.sim.mfg.data.domain.type.GoodType;
import com.sim.mfg.data.domain.type.RelationshipType;
/**
*
* @author damien
*
*/
@Entity
@Table(name = "GOOD")
@Where(clause="enabled=1") //Used for logical delete, disabled objects are always hidden
public class Good extends AMfgObject implements Serializable {
/** serialVersionUID */
private static final long serialVersionUID = -7656499731749432022L;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "GOOD_ID", nullable = false)
private Long id;
@Enumerated(EnumType.STRING)
@Column(name = "TYPE", nullable = false)
private GoodType type;
@Column(name = "STATUS")
private String status;
@Column(name = "PRODUCTION_DATE")
private Date productionDate;
@Column(name = "EXPIRY_DATE")
private Date expiryDate;
@JoinColumn(name = "PRODUCT_ID", nullable = false)
@ManyToOne(fetch = FetchType.LAZY, optional = false)
private Product product;
@JoinColumn(name = "FILL_ID")
@ManyToOne(fetch = FetchType.LAZY)
private Fill fill;
@OneToMany(fetch = FetchType.LAZY, mappedBy = "good", cascade = CascadeType.ALL)
@MapKeyColumn(name="TYPE")
@MapKeyEnumerated(EnumType.STRING)
private Map<RelationshipType, Relationship> relationships = new HashMap<RelationshipType, Relationship>();
@OneToMany(fetch = FetchType.LAZY, mappedBy = "good")
private Set<Code> codes;
@OneToMany(fetch = FetchType.EAGER, mappedBy = "good",cascade=CascadeType.ALL)
private Set<GoodStatus> goodStatus;
/**
* Empty constructor
*/
public Good(){}
/**
* Good constructor
* @param type
*/
public Good(GoodType type) {
super();
this.type = type;
}
/**
* Good constructor
* @param type
* @param product
*/
public Good(GoodType type, Product product) {
this(type, product, null, null);
}
/**
* Good constructor
* @param type
* @param product
* @param productionDate
* @param expiryDate
*/
public Good(GoodType type, Product product, Date productionDate, Date expiryDate) {
super();
this.type = type;
this.product = product;
this.productionDate = productionDate;
this.expiryDate = expiryDate;
}
@Override
public void editFrom(AMfgObject object) {
// Not needed for this object
}
/**
* Get relationship for given type
* @param type
* @return
*/
public Relationship getRelationship(RelationshipType type) {
return relationships.get(type);
}
/**
* Add relationship of given type with the given good
* @param type
* @param withGood
*/
public void addRelationship(RelationshipType type, Good withGood) {
if (!relationships.containsKey(type))
relationships.put(type, new Relationship(this, type));
relationships.get(type).add(withGood);
}
/**
* Removed relationship of given type with the given good
* @param type
* @param withGood
*/
public void removeRelationship(RelationshipType type, Good withGood) {
if (relationships.containsKey(type))
relationships.get(type).remove(withGood);
}
/**
* Removed all relationships with the given good
* @param withGood
*/
public void removeAllRelationships(Good withGood) {
relationships.values().forEach(relationship -> relationship.remove(withGood));
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getStatus() {
return status;
}
public void setStatus(String status) {
this.status = status;
}
public Product getProduct() {
return product;
}
public void setProduct(Product product) {
this.product = product;
}
public Fill getFill() {
return fill;
}
public void setFill(Fill fill) {
this.fill = fill;
}
public Map<RelationshipType, Relationship> getRelationships() {
return relationships;
}
public void setRelationships(Map<RelationshipType, Relationship> relationships) {
this.relationships = relationships;
}
public GoodType getType() {
return type;
}
public void setType(GoodType type) {
this.type = type;
}
public Set<Code> getCodes() {
return codes;
}
public void setCodes(Set<Code> codes) {
this.codes = codes;
}
public Date getProductionDate() {
return productionDate;
}
public void setProductionDate(Date productionDate) {
this.productionDate = productionDate;
}
public Date getExpiryDate() {
return expiryDate;
}
public void setExpiryDate(Date expiryDate) {
this.expiryDate = expiryDate;
}
public Set<GoodStatus> getGoodStatus() {
return goodStatus;
}
public void setGoodStatus(Set<GoodStatus> goodStatus) {
this.goodStatus = goodStatus;
}
/**
* add GoodStatus directly
* @param goodStatus
*/
public void addGoodStatus(GoodStatus goodStatus){
this.goodStatus.add(goodStatus);
goodStatus.setGood(this); //不设置这句就不会执行update语句!!
}
}
多的一方:
package com.sim.mfg.data.domain;
import java.io.Serializable;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.EnumType;
import javax.persistence.Enumerated;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.OneToOne;
import javax.persistence.Table;
import org.hibernate.annotations.Where;
import com.sim.mfg.data.domain.event.EndUserScan;
import com.sim.mfg.data.domain.type.GoodStatusType;
@Entity
@Table(name = "GOODSTATUS")
@Where(clause = "enabled=1")
public class GoodStatus extends AMfgObject implements Serializable {
/**
*
*/
private static final long serialVersionUID = -1279190303132720639L;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "GOODSTATUS_ID", nullable = false)
private Long id;
@Enumerated(EnumType.STRING)
@Column(name = "TYPE")
private GoodStatusType type;
@Column(name = "VALUE")
private String value;
@JoinColumn(name = "ENDUSERSCAN_ID", nullable = false)
@OneToOne(optional = true, fetch = FetchType.LAZY)
private EndUserScan scan;
@JoinColumn(name = "GOOD_ID")
@ManyToOne(optional = true, fetch = FetchType.LAZY,cascade={CascadeType.MERGE,CascadeType.REFRESH})
private Good good;
public GoodStatus() {
super();
}
public GoodStatusType getType() {
return type;
}
public void setType(GoodStatusType type) {
this.type = type;
}
public String getValue() {
return value;
}
public void setValue(String value) {
this.value = value;
}
public EndUserScan getScan() {
return scan;
}
public void setScan(EndUserScan scan) {
this.scan = scan;
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public Good getGood() {
return good;
}
public void setGood(Good good) {
this.good = good;
}
@Override
public void editFrom(AMfgObject object) {
// TODO Auto-generated method stub
}
}
在GoodService里:
@Override
public void addstatus(Long goodId, GoodStatus goodStatus) {
Good good=goodRepository.findOne(goodId);
good.addGoodStatus(goodStatus);
goodRepository.save(good);
}
工作中遇到的问题--Hibernate一对多保存简化Service层代码的更多相关文章
- 工作中遇到的问题--JPA 一对多查询
/** * order by gs.updateDate desc * SELECT gs FROM GoodStatus gs WHERE gs IN( * @ ...
- 工作中遇到的问题--Hibernate注解添加在一方和多方的区别
以Good和GoodStatus为例: 一.注解仅添加在一方: @Entity@Table(name = "GOOD")@Where(clause="enabled=1& ...
- Hibernate 一对多 保存和修改数据
Student和Sclass表,Student外键cid是Sclass的cid create table sclass( cid ) primary key, cname ) )go create t ...
- 工作中遇到的vscode配合eslint完成保存为eslint格式
vscode个人设置 // vscode的个人设置配置 { "workbench.iconTheme": "vscode-icons", "workb ...
- Hibernate一对多操作
--------------------siwuxie095 Hibernate 一对多操作 以客户和联系人为例,客户是一,联系人是多 即 一个客户里面有多个联系人,一个联系人只能属于一个客户 注意: ...
- Hibernate 一对多
表与表之间关系回顾(重点) 1 一对多 (1)分类和商品关系,一个分类里面有多个商品,一个商品只能属于一个分类 (2)客户和联系人是一对多关系 - 客户:与公司有业务往来,百度.新浪.360 - 联系 ...
- hibernate 一对多双向关联 详解
一.解析: 1. 一对多双向关联也就是说,在加载班级时,能够知道这个班级所有的学生. 同时,在加载学生时,也能够知道这个学生所在的班级. 2.我们知道,一对多关联映射和多对一关联映射是一样的,都是在 ...
- Hibernate一对多OnetoMany
------------------------Hibernate一对多OnetoMany 要点: 配置在一端. 1.如果是单向关联,即只在一端配置OneToMany,多端不配置ManyToOne.则 ...
- Hibernate一对多关系操作
1.创建两个实体类. 一个实体类是商品类,另一个实体类是商品的分类类. 在一对多关系的两个实体中,在编写实体类时必须要遵循以下规则: (1)在一的那一方的实体中,必须要有一个私有的多那一方的实体对象属 ...
随机推荐
- (转)iOS应用架构谈 view层的组织和调用方案
前言 <iOS应用架构谈 开篇>出来之后,很多人来催我赶紧出第二篇.这一篇文章出得相当艰难,因为公司里的破事儿特别多,我自己又有点私事儿,以至于能用来写博客的时间不够充分. 现在好啦,第二 ...
- 中南民航如何利用K2BPM构建业务流程?
广州市中南民航空管通信网络科技有限公司成立于2004年9月,负责民航中南地区通信网络.电报网络的建设与维护.民航空管信息系统的开发与维护.公司拥有一支技术精湛的研发队伍,在信息技术领域领跑于民航空管行 ...
- c#读取文本文档实践2-计算商品价格
商品 数量 单价英语 66 100语文 66 80数学 66 100化学 66 40物理 66 60 上面是文本文档中读入的数据. using System; using System.Collect ...
- [微软]technet与msdn
我们搜索一个微软术语,有时定位到technet页面,有时定位到msdn页面.我直观的理解就是technet教人们如何使用微软产品,而msdn指导人们如何开发基于微软产品的软件.那么微软对它们具体定位是 ...
- 加强版for循环
/*加强版for循环 * 5.0以后有加强版for循环 * for(String name:nameArray){} * 1.String name:声明会带有数组单一元素的循环变量 * 数组元素 ...
- tableView中的“点击加载更多”点击不到
假设当前的tableView是_tableView,则可以这样设置 _tableView.contentInset = UIEdgeInsetsMake(0, 0, 100, 0); 该属性用于设置当 ...
- linux安装时出现your cpu does not support long mode的解决方法
如果你确定你的电脑支持64bit且是64bit的宿主系统,则需要修改BIOS中的Inter Virtualization Technology为enabled.
- css3制作六边形图片
效果图: 实现原理: 这个效果的主要css样式有: 1.>transform: rotate(120deg); 图片旋转 2.>overflow:hidden; 超出隐藏 3.>v ...
- Android开发指南-框架主题-安全和许可
概述:Android操作系统是一个安全便捷的Linux系统,遵循Linux系统机制,允许多进程.为了进程间的数据共享和交互共用,设计"权限"这个名词,声明权限代表可使用此权限,未声 ...
- JQuery blockUI
1 $.blockUI({//界面锁定之后 ,显示样式和提示消息 css: { width: 'auto', left: '20px', right: '20px' }, message: '< ...