mybatis 差异更新法

主表酒店(blue_hotel)和子表房间(blue_hotel_room)

1.先找出要删除的房间(存在于旧房间但不在新房间中),筛选出新房间的id,然后拿新房间的id去和旧房间做过滤,最后得到结果。代码示例

java 复制代码
    /**
     * 找出需要删除的房间(存在于oldRooms但不在newRooms中)
     *
     * @param oldRooms
     * @param newRooms
     * @return
     */
    private List<BlueHotelRoom> findRoomsToDelete(List<BlueHotelRoom> oldRooms, List<BlueHotelRoom> newRooms) {
        // 收集新房间中的所有ID(使用Set提高查找效率)
        Set<Long> newRoomIds = newRooms.stream()
                .map(BlueHotelRoom::getHotelRoomId)
                .filter(Objects::nonNull)
                .collect(Collectors.toSet());

        // 返回旧房间中不在新房间ID集合中的房间
        return oldRooms.stream()
                .filter(room -> !newRoomIds.contains(room.getHotelRoomId()))
                .collect(Collectors.toList());
    }

2.找出需要新增或更新的房间。将旧房间的数据转换为Map<房间ID,房间对象>的数据形式,然后拿新房间的数据做过滤,新房间中的id等于空或者不在旧房间中,证明是需要新增或者更新的房间,最后检查其它字段的数据一致,不一致则更新字段。示例代码

java 复制代码
 /**
     * 找出需要新增或更新的房间
     *
     * @param oldRooms
     * @param newRooms
     * @return
     */
    private List<BlueHotelRoom> findRoomsToAddOrUpdate(List<BlueHotelRoom> oldRooms, List<BlueHotelRoom> newRooms) {
        // 收集旧房间中的所有ID(使用Map提高查找效率)
        Map<Long, BlueHotelRoom> oldRoomMap = oldRooms.stream()
                .collect(Collectors.toMap(BlueHotelRoom::getHotelRoomId, room -> room));

        return newRooms.stream()
                .filter(room -> {
                    // 新增房间(ID为null或不在旧房间中)
                    if (room.getHotelRoomId() == null) return true;
                    if (!oldRoomMap.containsKey(room.getHotelRoomId())) return true;

                    // 检查是否需要更新(比较关键字段)
                    BlueHotelRoom oldRoom = oldRoomMap.get(room.getHotelRoomId());
                    return !Objects.equals(room.getHotelRoomName(), oldRoom.getHotelRoomName()) ||
                            !Objects.equals(room.getOrderNum(), oldRoom.getOrderNum());
                    // 添加其他需要比较的字段
                })
                .collect(Collectors.toList());
    }

3.最后更新的时候先更新主表数据,也就是酒店的数据。然后查询现有的房间数据,也就是旧的房间数据(oldRooms)新的房间数据就是传过来的房间数据(newRooms),最后调用两用上面两个方法,该删除的删除,该新增的新增。示例代码

java 复制代码
  /**
     * 修改酒店管理
     *
     * @param blueHotel 酒店管理
     * @return 结果
     */
    @Transactional
    @Override
    public int updateBlueHotel(BlueHotel blueHotel) {
        blueHotel.setUpdateTime(DateUtils.getNowDate());

        List<BlueHotelRoom> newRooms = blueHotel.getBlueHotelRoomList();
        // 1. 更新主表
        int rows = blueHotelMapper.updateBlueHotel(blueHotel);

        // 2. 查询现有房间
        List<BlueHotelRoom> oldRooms = blueHotelMapper.selectBlueHotelRoomByHotelId(blueHotel.getHotelId());

        // 3. 找出需要删除的房间(存在于old但不在new中)
        List<BlueHotelRoom> toDelete = findRoomsToDelete(oldRooms, newRooms);
        toDelete.forEach(room -> {
            blueHotelMapper.deleteBlueHotelRoomByHotelRoomId(room.getHotelRoomId());
        });

        // 4. 找出需要新增/更新的项目
        List<BlueHotelRoom> toAddOrUpdate = findRoomsToAddOrUpdate(oldRooms, newRooms);
        toAddOrUpdate.forEach(room -> {
            room.setHotelId(blueHotel.getHotelId());
            if (room.getHotelRoomId() == null) {
                blueHotelMapper.insertBlueHotelRoom(room);
            } else {
                blueHotelMapper.updateBlueHotelRoom(room);
            }
        });


        return rows;
    }
相关推荐
-D调定义之崽崽5 分钟前
【初学】调试 MCP Server
前端·mcp
四月_h24 分钟前
vue2动态实现多Y轴echarts图表,及节点点击事件
前端·javascript·vue.js·echarts
文心快码BaiduComate1 小时前
用Zulu轻松搭建国庆旅行4行诗网站
前端·javascript·后端
草莓熊Lotso1 小时前
从 “Hello AI” 到企业级应用:Spring AI 如何重塑 Java 生态的 AI 开发
java·人工智能·经验分享·后端·spring
doulbQuestion1 小时前
【无标题】
java·spring
Metaphor6921 小时前
Java 旋转 PDF 页面:使用 Spire.PDF 实现高效页面处理
java·经验分享·pdf
哈利路亚胡辣汤2 小时前
spring多数据源配置
java·spring·mybatis
卷Java2 小时前
智慧停车大屏数据分析与设计文档
java·大数据·人工智能·数据分析
行者..................2 小时前
手动编译 OpenCV 4.1.0 源码,生成 ARM64 动态库 (.so),然后在 Petalinux 中打包使用。
前端·webpack·node.js
聪明的笨猪猪3 小时前
Java SE “JDK1.8新特性”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试