IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发工具 -> 第二十七弹,JPA如何使用注解实现一对多两端同时保存,并且查询同时查出 -> 正文阅读

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

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

一端PO如下:

/**
 * 事故管理-PO
 * @version 2021-5-14 09:16:36
 */
@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*/
    @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<OcAccidentDetailPO> ocAccidentDetailPOSet = new HashSet<OcAccidentDetailPO>();
	
	gettingsetting省略。。。

多端PO如下:

/**
 * 事故管理明细-PO
 * @version 2021-5-14 09:34:09
 */
@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字段

保存时如下:

/**
  * 添加/修改
  * @param ocAccidentPO 添加/修改对象
  * @param userId 当前用户id
  * @return 数据
  * @throws Exception 异常信息
  */
 @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官网

  开发工具 最新文章
Postman接口测试之Mock快速入门
ASCII码空格替换查表_最全ASCII码对照表0-2
如何使用 ssh 建立 socks 代理
Typora配合PicGo阿里云图床配置
SoapUI、Jmeter、Postman三种接口测试工具的
github用相对路径显示图片_GitHub 中 readm
Windows编译g2o及其g2o viewer
解决jupyter notebook无法连接/ jupyter连接
Git恢复到之前版本
VScode常用快捷键
上一篇文章      下一篇文章      查看所有文章
加:2022-03-21 21:12:07  更:2022-03-21 21:12:44 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/2 2:03:33-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码