【雷丰阳-谷粒商城 】【分布式基础篇-全栈开发篇】【08】【商品服务】Object划分_批量删除


持续学习&持续更新中...

守破离


【雷丰阳-谷粒商城 】【分布式基础篇-全栈开发篇】【08】【商品服务】Object划分_批量删除

Object划分


  • 数据库中对于一张表的数据,由于拥有隐私字段、多余字段、字段过少等原因,不应该直接传递给客户端让客户端直接使用。
  • 并且要知道数据的传输是要经过网络通信的,考虑到数据大小对于用户流量、系统并发量/吞吐量等的影响,我们也不应该给客户传递冗余或者缺失的JSON数据。
  • 还有很多原因
    • 比如我们的一个业务所需要的信息有时候其实并不是仅由一张表就能覆盖的
    • 比如数据库中的字段信息其实并不适合展示给用户看,需要做处理
    • 前端发过来的数据,使用一个简单的数据库对象也并不一定能处理好
    • ...
  • 综上,我们肯定要对从数据库中查询出来的表数据进行一些加工处理、业务逻辑处理之后再传递给上一层,直到客户端,而不是简单的一张表对应一个Model对象。

批量删除/添加

一句一句删除的话,会发送很多个请求给MySQL服务器,会对MySQL造成较大的性能影响,也会占用资源和带宽,所以使用批量删除

java 复制代码
    //TODO 写博客:批量删除
    @PostMapping("/attr/relation/delete")
    public R batchDeleteRelation(@RequestBody List<AttrAttrGroupRelationVo> relationVos) {
        relationService.batchDeleteRelation(relationVos);
        return R.ok();
    }
java 复制代码
    @Transactional
    @Override
    public void batchDeleteRelation(List<AttrAttrGroupRelationVo> relationVos) {
        this.baseMapper.batchDeleteRelation(relationVos);
    }
java 复制代码
@Mapper
public interface AttrAttrgroupRelationDao extends BaseMapper<AttrAttrgroupRelationEntity> {

    /*
    一句一句删除的话,会发送很多个请求给MySQL服务器,会对MySQL造成较大的性能影响,也会占用资源和带宽,所以使用批量删除

    批量删除语句:
    DELETE FROM pms_attr_attrgroup_relation
    WHERE
    ('attr_id' = 1 AND 'attr_group_id' = 1)
    OR
    ('attr_id' = 3 AND 'attr_group_id' = 2)
    OR ...
     */

    void batchDeleteRelation(@Param("relations") List<AttrAttrGroupRelationVo> relationVos);

}
java 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="com.atguigu.gulimall.product.dao.AttrAttrgroupRelationDao">

    <!-- 可根据自己的需求,是否要使用 -->
    <resultMap type="com.atguigu.gulimall.product.entity.AttrAttrgroupRelationEntity" id="attrAttrgroupRelationMap">
        <result property="id" column="id"/>
        <result property="attrId" column="attr_id"/>
        <result property="attrGroupId" column="attr_group_id"/>
        <result property="attrSort" column="attr_sort"/>
    </resultMap>

    <delete id="batchDeleteRelation">
        DELETE FROM `pms_attr_attrgroup_relation` WHERE
        <foreach collection="relations" item="item" separator=" OR ">
            (attr_id=#{item.attrId} AND attr_group_id=#{item.attrGroupId})
        </foreach>
    </delete>

</mapper>

批量添加:

xml 复制代码
    <insert id="batchAddRelation">
        INSERT INTO  `pms_attr_attrgroup_relation`(attr_id, attr_group_id) VALUES
        <foreach collection="relations" item="item" separator=",">
            (#{item.attrId} , #{item.attrGroupId})
        </foreach>
    </insert>

or

java 复制代码
    @Transactional
    @Override
    public void batchAddRelation(List<AttrAttrGroupRelationVo> relationVos) {
//        使用自己写的批量添加也可以
//        this.baseMapper.batchAddRelation(relationVos);

        List<AttrAttrgroupRelationEntity> collect = relationVos.stream().map(relation -> {
            AttrAttrgroupRelationEntity attrAttrgroupRelationEntity = new AttrAttrgroupRelationEntity();
//            attrAttrgroupRelationEntity.setAttrId(relation.getAttrId());
//            attrAttrgroupRelationEntity.setAttrGroupId(relation.getAttrGroupId());
            BeanUtils.copyProperties(relation, attrAttrgroupRelationEntity);
            return attrAttrgroupRelationEntity;
        }).collect(Collectors.toList());
        this.saveBatch(collect);
    }

参考

雷丰阳: Java项目《谷粒商城》Java架构师 | 微服务 | 大型电商项目.


本文完,感谢您的关注支持!


相关推荐
泡泡以安8 分钟前
【Android逆向工程】第3章:Java 字节码与 Smali 语法基础
android·java·安卓逆向
毕设源码-朱学姐6 小时前
【开题答辩全过程】以 工厂能耗分析平台的设计与实现为例,包含答辩的问题和答案
java·vue.js
Spring AI学习7 小时前
Spring AI深度解析(9/50):可观测性与监控体系实战
java·人工智能·spring
unique_perfect8 小时前
vue2与springboot实现deepseek打印机聊天
spring boot·websocket·ai·vue2·deepseek
java1234_小锋8 小时前
Spring IoC的实现机制是什么?
java·后端·spring
xqqxqxxq8 小时前
背单词软件技术笔记(V2.0扩展版)
java·笔记·python
消失的旧时光-19439 小时前
深入理解 Java 线程池(二):ThreadPoolExecutor 执行流程 + 运行状态 + ctl 原理全解析
java·开发语言
哈哈老师啊9 小时前
Springboot学生综合测评系统hxtne(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·数据库·spring boot
4311媒体网9 小时前
帝国cms调用文章内容 二开基本操作
java·开发语言·php
梁萌9 小时前
MySQL数据库分库分表介绍
数据库·mysql·shardingsphere·分库分表