栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

第二十七弹,JPA如何使用注解实现一对多两端同时保存,并且查询同时查出

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

第二十七弹,JPA如何使用注解实现一对多两端同时保存,并且查询同时查出

第二十七弹,JPA如何使用注解实现一对多两端同时保存,并且查询同时查出

一端PO如下:

@Entity
@Table(name = "oc_accident",indexes = {@Index(name = "index_create_user",columnList = "create_user"),
        @Index(name = "index_update_user",columnList = "update_user")})
@ApiModel("事故管理")
public class OcAccidentPO implements Serializable {

    
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "id")
    @ApiModelProperty(value = "主键Id")
    private Integer id;

    
    @Basic
    @Column(name = "create_time")
    @JSONField(format = "yyyy-MM-dd HH:mm:ss")
    @ApiModelProperty(value = "创建时间")
    private Date createTime;

    
    @Basic
    @Column(name = "create_user")
    @ApiModelProperty(value = "创建人")
    private Integer createUser;

    
    @Basic
    @Column(name = "update_time")
    @JSONField(format = "yyyy-MM-dd HH:mm:ss")
    @ApiModelProperty(value = "修改时间")
    private Date updateTime;

    
    @Basic
    @Column(name = "update_user")
    @ApiModelProperty(value = "修改人")
    private Integer updateUser;

    
    @Valid
    @OneToMany(cascade={CascadeType.PERSIST,CascadeType.MERGE,CascadeType.REMOVE,CascadeType.REFRESH}
            ,orphanRemoval = true,mappedBy="ocAccidentPO",fetch=FetchType.EAGER)
    private Set ocAccidentDetailPOSet = new HashSet();
	
	gettingsetting省略。。。

多端PO如下:

@Entity
@Table(name = "oc_accident_detail")
@ApiModel("事故管理明细")
public class OcAccidentDetailPO implements Serializable {

    
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "id")
    @ApiModelProperty(value = "主键Id")
    private Integer id;

    
    @Basic
    @Column(name = "create_time")
    @JSONField(format = "yyyy-MM-dd HH:mm:ss")
    @ApiModelProperty(value = "创建时间")
    private Date createTime;

    
    @Basic
    @Column(name = "create_user")
    @ApiModelProperty(value = "创建人")
    private Integer createUser;

    
    @Basic
    @Column(name = "update_time")
    @JSONField(format = "yyyy-MM-dd HH:mm:ss")
    @ApiModelProperty(value = "修改时间")
    private Date updateTime;

    
    @Basic
    @Column(name = "update_user")
    @ApiModelProperty(value = "修改人")
    private Integer updateUser;

    
    @ManyToOne(cascade={CascadeType.REFRESH},fetch = FetchType.LAZY)
    @JoinColumn(name="accident_id")
    private OcAccidentPO ocAccidentPO;

	gettingsetting省略。。。

@JoinColumn(name=“accident_id”)注解代表会在多端数据库表自动生成accident_id字段

保存时如下:

 @Override
 @Transactional(rollbackFor = Exception.class)
 public OcAccidentPO save(OcAccidentPO ocAccidentPO, Integer userId) throws Exception {
     if(ocAccidentPO == null){
         throw new Exception("要添加的数据不能为空");
     }
     if(ocAccidentPO.getOcAccidentDetailPOSet() != null && ocAccidentPO.getOcAccidentDetailPOSet().size() > 0){
         for(OcAccidentDetailPO item : ocAccidentPO.getOcAccidentDetailPOSet()){
             if(item.getId() != null){
                 //修改
                 item.setUpdateUser(userId);
                 item.setUpdateTime(Calendar.getInstance().getTime());
             }else{
                 //添加
                 item.setCreateTime(Calendar.getInstance().getTime());
                 item.setCreateUser(userId);
                 item.setUpdateUser(userId);
                 item.setUpdateTime(Calendar.getInstance().getTime());
             }
             item.setOcAccidentPO(ocAccidentPO);
         }
     }

     if(ocAccidentPO.getId() == null){
         //添加
         ocAccidentPO.setCreateTime(Calendar.getInstance().getTime());
         ocAccidentPO.setCreateUser(userId);
         ocAccidentPO.setUpdateUser(userId);
         ocAccidentPO.setUpdateTime(Calendar.getInstance().getTime());
     }else{
         //修改
         ocAccidentPO.setUpdateTime(Calendar.getInstance().getTime());
         ocAccidentPO.setUpdateUser(userId);
     }
     return ocAccidentDao.save(ocAccidentPO);
 }

需要注意的是,此功能为JPA级联保存修改删除,详情请参考jpa官网

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/776396.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号