P11 品牌管理

P75 品牌分类关联和级联更新

第一步

1、把renren-fast-vue\src\views\modules下的common和product模块复制到vue中

2、mybatisplus的分页插件,来调整品牌管理页面的页数不对问题

product新建config/MybatisPlusConfig.java文件,参照官网,添加依赖,导入类

mapperScan扫描的包是dao层下的,其他一样

@MapperScan("com.atguigu.gulimail.product.dao")

3、品牌管理页面的查询功能不对

是在brandController的list请求中

StringUtils用的是lang包下的

String s = (String) params.get("key");QueryWrapper<BrandEntity> brandEntityQueryWrapper = new QueryWrapper<>();if(!StringUtils.isEmpty(s)){brandEntityQueryWrapper.eq("brand_id",s).or().like("name",s);}IPage<BrandEntity> page = this.page(new Query<BrandEntity>().getPage(params),brandEntityQueryWrapper);

4、执行pms.sql恢复原始形状,删除所有数据

第二步

1、品牌管理页面,关联分类显示信息

/product/categorybrandrelation/catelog/list
CategoryBrandRelationController.java
@RequestMapping("/catelog/list")public R categoryList(@RequestParam("brandId") Long brandId){List<CategoryBrandRelationEntity> list = categoryBrandRelationService.list(new QueryWrapper<CategoryBrandRelationEntity>().eq("brand_id",brandId));return R.ok().put("page", list);}

2、保存关联分类详细信息

@RequestMapping("/save")public R save(@RequestBody CategoryBrandRelationEntity categoryBrandRelation){// 查到对应的品牌名称和分类名称categoryBrandRelationService.saveDetail(categoryBrandRelation);return R.ok();}

这里面三方表自动注入 不是service,否则双向依赖。

品牌有注入关联表,关联表也注入有品牌服务。

这里用 Dao!

@Autowired
private CategoryDao categoryDao;
@Autowired
private BrandDao brandDao;
public void saveDetail(CategoryBrandRelationEntity categoryBrandRelation) {Long brandId = categoryBrandRelation.getBrandId();Long catelogId = categoryBrandRelation.getCatelogId();// 查询品牌名和分类名BrandEntity brand = brandDao.selectById(brandId);CategoryEntity category = categoryDao.selectById(catelogId);categoryBrandRelation.setBrandName(brand.getName());categoryBrandRelation.setCatelogName(category.getName());this.save(categoryBrandRelation);}

第三步

品牌页面更新名字时,category_brand数据表也要更新

是用的update里面,不是save

@RequestMapping("/update")public R update(@Validated({UpdataGroup.class}) @RequestBody BrandEntity brand){brandService.updateDetail(brand);return R.ok();}
@Autowired
private CategoryBrandRelationService categoryBrandRelationService;@Transactional
@Override
public void updateDetail(BrandEntity brand) {this.updateById(brand);// 更新其他关联表if(!StringUtils.isEmpty(brand.getName())){categoryBrandRelationService.updateBrandName(brand.getBrandId(),brand.getName());}}    
@Overridepublic void updateCatelogName(Long catId, String name) {CategoryBrandRelationEntity categoryBrandRelation = new CategoryBrandRelationEntity();categoryBrandRelation.setCatelogId(catId);categoryBrandRelation.setBrandName(name);this.update(categoryBrandRelation,new UpdateWrapper<CategoryBrandRelationEntity>().eq("catelog_id",catId));}

第四步

同理,分类信息更新时,category_brand数据表也要更新

@RequestMapping("/update")public R update(@RequestBody CategoryEntity category){categoryService.updateDetail(category);return R.ok();}
@Transactional
@Overridepublic void updateDetail(CategoryEntity category) {this.updateById(category);// 更新其他关联表if(!StringUtils.isEmpty(category.getName())){categoryBrandRelationService.updateCatelogName(category.getCatId(), category.getName());}}

换一种方法实现,用mybatisplus。需要安装mybatisX插件

@Overridepublic void updateCatelogName(Long catId, String name) {this.baseMapper.updateCatelogName(catId, name);}

之后自动创建方法,提示生成。起名字

@Mapper
public interface CategoryBrandRelationDao extends BaseMapper<CategoryBrandRelationEntity> {void updateCatelogName(@Param("id") Long catId,@Param("name") String name);
}
<update id="updateCatelogName">UPDATE pms_category_brand_relation SET catelog_name = #{name}  WHERE catelog_id = #{id}</update>

其他

异常根类是Throwable,它有两个子类:

Error: 错误,非常严重

Exception:编译时异常,写代码时的异常。也就是平时所说的异常,使用不当导致,可避免。它有个子类:

RuntimeException:运行时异常

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/850697.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【人工智能】AI绘画工具基本介绍

AI绘画工具是一种利用人工智能技术&#xff0c;特别是深度学习和神经网络&#xff0c;来生成图像的软件或在线服务。这些工具能够根据用户的指令或描述&#xff0c;创造出各种风格的图像&#xff0c;包括但不限于风景、人物、动物、抽象艺术等。AI绘画工具的出现&#xff0c;极…

python中的循环语句

while循环 基本语法格式 while 条件&#xff1a; 循环体 条件为真&#xff0c;则执行循环体代码 条件为假&#xff0c;则结束循环 打印 1-10的整数 死循环有时候也是必须的&#xff0c; while语句的语法&#xff1a; &#xff08;1&#xff09;变量的初始化&#xff0c;…

你知道又美又飒的英歌队头槌女孩吗?无标题

今天是文化和自然遗产日&#xff0c;本“ 人民体验官 ”推广人民日报官方微博文化产品《 16岁英歌队头槌女孩又美又飒》。 截图&#xff1a;来源“ 人民体验官 ”推广平台 郑梓欣是汕头潮阳西门女子英歌队的“头槌”。在2024年春节英歌舞展演巡游活动中&#xff0c;汕头潮阳西…

MySQL第二种实现方式:现在有一个生产计划,甲乙丙3个品类共16个产品,生产时间6天,每天甲品类可以生产1张单,乙3张,丙1张,请用MySQL写出H列的效果

接上篇&#xff1a;链接: 现在有一个生产计划&#xff0c;甲乙丙3个品类共16个产品&#xff0c;生产时间6天&#xff0c;每天甲品类可以生产1张单&#xff0c;乙3张&#xff0c;丙1张&#xff0c;请用MySQL写出H列的效果 第二种写法&#xff1a; -- 使用WITH子句创建CTE WITH…

Spark参数配置不合理的情况

1.1 内存设置 &#x1f4be; 常见的内存设置有两类&#xff1a;堆内和堆外 &#x1f4a1; 我们作业中大量的设置 driver 和 executor 的堆外内存为 4g&#xff0c;造成资源浪费 &#x1f4c9;。 通常 executor 堆外内存在 executor.cores1 的时候&#xff0c;1g 足够了&…

UltraEditUEStudio软件最新版下载及详细安装教程

UEStudio简介&#xff1a; UEStudio建立在上文本编辑器UltraEdit的功能基础上&#xff0c;并为团队和开发人员提供了其他功能&#xff0c;例如深度Git集成。您可以直接在UEStudio中克隆&#xff0c;签出&#xff0c;更新&#xff0c;提交&#xff0c;推入/拉入等操作&#xff…

再回首:我的创作纪念日3周年回顾

机缘 我与CSDN三周年博客纪念 大家好&#xff01;今天&#xff0c;我非常高兴地在这里向大家分享我与CSDN三周年博客纪念的喜悦和成果。在这三年里&#xff0c;我坚持不懈地在CSDN上分享了我的技术成果和心得&#xff0c;积累了超过2000篇的博客文章。这一路上&#xff0c;我…

Invalid JSON text:“Invalid value.“ at position 0 in value for column ‘user.info

你们好&#xff0c;我是金金金。 场景 我正在练习mybatis-plus&#xff0c;在插入一条数据的时候报错了&#xff0c;错误信息如上图 排查 排查之前我先贴一下代码 以下为数据库字段类型 在插入的过程中报错&#xff1a;Data truncation: Invalid JSON text: "Invalid val…

python中的函数递归

函数递归&#xff0c;就是一个函数&#xff0c;自己调用自己。 如上图所示&#xff0c;是一段通过定义函数&#xff0c;编写函数体来实现for循环。实现的是从1到n的累乘。即求n的阶乘&#xff0c; 如上图所示&#xff0c;是一段函数的递归来实现1到n的累乘操作&#xff0c;将1*…

opencv快速安装以及各种查看版本命令

安装opencv并查看其版本&#xff0c;直接通过一个可执行文件实现。 #!/bin/bashwget https://codeload.github.com/opencv/opencv/zip/3.4 -O opencv-3.4.zip && unzip opencv-3.4.zip && cd opencv-3.4 && \mkdir build && cd build &&a…

Sentinel不使用控制台基于注解限流,热点参数限流

目录 一、maven依赖 二、控制台 三、基于注解限流 四、热点参数限流 五、使用JMeter验证 一、maven依赖 需要注意&#xff0c;使用的版本需要和你的SpringBoot版本匹配&#xff01;&#xff01; Spring-Cloud直接添加如下依赖即可&#xff0c;baba已经帮你指定好版本了。…

海洋日特别活动—深海来客——可燃冰

深海中有一种神奇的物质&#xff0c;似冰又不是冰。 别看它其貌不扬&#xff0c;但本领不小&#xff0c;遇火即燃&#xff0c;能量巨大&#xff0c;可谓是能源家族的新宠。它就是被国务院正式批准列为我国第173个矿种的“可燃冰”&#xff01; 可燃冰到底是个啥&#xff1f;它…

python之集合访问

在Python中&#xff0c;集合&#xff08;set&#xff09;是一种无序且不包含重复元素的数据结构。由于集合是无序的&#xff0c;因此不能像列表或元组那样通过索引来直接访问集合中的特定元素。但是&#xff0c;你可以通过遍历集合中的所有元素来间接地访问它们。 以下是几种访…

把chatgpt当实习生,进行matlab gui程序编程

最近朋友有个项目需要整点matlab代码&#xff0c;无奈自己对matlab这种工科的软件完全是外行&#xff0c;无奈只有求助gpt这种AI助手了。大神们告诉我们&#xff0c;chatgpt等的助手已经是大学实习生水平啦&#xff0c;通过多轮指令交互就可以让他帮你完成工作啦&#xff01;所…

Openstack学习(1)——架构

OpenStack是一个开源的云计算管理平台项目&#xff0c;它提供了一套完整的软件堆栈来构建和管理私有云、公有云以及混合云环境。 核心组件与功能 计算&#xff08;Compute&#xff09;&#xff1a;通过Nova项目提供虚拟机和容器的管理和调度功能&#xff0c;支持快速创建、部…

时隔很久运行苍穹外卖项目,出现很多错误

中途运行了很多其他项目&#xff0c;maven的配置文件还被我修改了一次。导致再次运行苍穹外卖项目出现很多错误。 发现没有办法&#xff0c;把本地的仓库删了个干干净净。然后点击clean发现报错&#xff1a; Cannot access alimaven (http://mavejavascript:void(0);n.aliyun.…

k8s学习--kubernetes服务自动伸缩之垂直伸缩(资源伸缩)VPA详细解释与安装

文章目录 前言VPA简介简单理解详细解释VPA的优缺点优点1.自动化资源管理2.资源优化3.性能和稳定性提升5.成本节约6.集成性和灵活性 缺点1.Pod 重启影响可用性2.与 HPA 冲突3.资源监控和推荐滞后&#xff1a;4.实现复杂度&#xff1a; 核心概念Resource Requests 和 Limits自动调…

学会python——九九乘法表+斐波那契数列(python实例一)

目录 1、认识Python 2、环境与工具 2.1 python环境 2.2 pycharm编译 2、九九乘法表 2.1 代码构思 2.2 代码示例 2.3 运行结果 3、斐波那契数列 3.1 代码构思 3.2 代码示例 3.3 运行结果 1、认识Python Python 是一个高层次的结合了解释性、编译性、互动性和面向对…

华为OD技术面试-连接后等于目标字符串的字符串对串-2024手撕代码真题

题目描述: 给你一个 数字 字符串数组 nums 和一个 数字 字符串 target ,请你返回 nums[i] + nums[j] (两个字符串连接)结果等于 target 的下标 (i, j) (需满足 i != j)的数目。 示例 1: 输入:nums = ["777","7","77","77"], …

Nginx部署多web进程

1、nginx介绍 Nginx是一个高性能的、开源的、跨平台的Web服务器和反向代理服务器。它是由俄罗斯的程序员Igor Sysoev开发的&#xff0c;并于2004年首次公开发布。 Nginx的特点包括&#xff1a; 高性能&#xff1a;Nginx使用事件驱动的架构&#xff0c;能够处理大量的并发连接…