From 20e0c1036ebc6d558e57644b770b9c9de8bcf383 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Thu, 23 Jan 2025 14:16:39 +0800
Subject: [PATCH] refactor(mall): 重构商品相关操作的验证逻辑
---
src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallGoodsService.java | 110 +++++++-----------------------------
src/main/java/cc/mrbird/febs/common/utils/ValidateEntityUtils.java | 13 +++-
src/main/java/cc/mrbird/febs/mall/dto/AddMallGoodsDto.java | 3
3 files changed, 32 insertions(+), 94 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/common/utils/ValidateEntityUtils.java b/src/main/java/cc/mrbird/febs/common/utils/ValidateEntityUtils.java
index 4833a8e..83a8b90 100644
--- a/src/main/java/cc/mrbird/febs/common/utils/ValidateEntityUtils.java
+++ b/src/main/java/cc/mrbird/febs/common/utils/ValidateEntityUtils.java
@@ -17,6 +17,7 @@
/**
* 确保指定列的有效性,并返回相应的实体对象
+ * selectOne方法
* 此方法用于验证数据库中某列的值是否存在,并返回包含该值的实体对象
* 如果指定的值不存在或为null,将抛出异常
*
@@ -54,7 +55,8 @@
if (columnExtractors != null && columnExtractors.length > 0) {
wrapper.select(columnExtractors);
}
- wrapper.eq(columnExtractor, valueToCheck);
+ wrapper.eq(columnExtractor, valueToCheck)
+ .last("limit 1");
// 执行查询并获取结果实体
entity = queryWrapperExtractor.apply(wrapper);
@@ -85,8 +87,9 @@
/**
* 确保指定列的有效性,并返回相应的实体对象列表
- * 此方法用于验证数据库中某列的值是否存在,并返回包含该值的实体对象列表
- * 如果指定的值不存在或为null,将抛出异常
+ * selectList方法
+ * 此方法用于验证数据库中某列的值是否存在,并返回包含该值的实体对象列表
+ * 如果指定的值不存在或为null,将抛出异常
*
* @param valueToCheck 需要验证的值
* @param columnExtractor 列值提取器,用于指定需要验证的列
@@ -135,7 +138,8 @@
}
/**
- * 确保指定列的值在数据库中是存在的,
+ * 确保指定列的值在数据库中是存在的
+ * selectOne方法
* 该方法通过查询数据库来验证给定的列值是否存在如果不存在,则抛出异常
*
* @param valueToCheck 需要验证的列值
@@ -183,6 +187,7 @@
/**
* 确保指定值在数据库中是唯一的
+ * selectCount方法
* 该方法通过查询数据库来验证给定的列值是否已经存在,如果存在,则抛出异常,以确保数据的唯一性
*
* @param valueToCheck 需要检查的值
diff --git a/src/main/java/cc/mrbird/febs/mall/dto/AddMallGoodsDto.java b/src/main/java/cc/mrbird/febs/mall/dto/AddMallGoodsDto.java
index fdf6ed7..06d4837 100644
--- a/src/main/java/cc/mrbird/febs/mall/dto/AddMallGoodsDto.java
+++ b/src/main/java/cc/mrbird/febs/mall/dto/AddMallGoodsDto.java
@@ -3,15 +3,16 @@
import io.swagger.annotations.ApiModel;
import lombok.Data;
+import javax.validation.constraints.NotBlank;
import java.math.BigDecimal;
import java.util.List;
@Data
@ApiModel(value = "AddMallGoodsDto", description = "参数接收类")
public class AddMallGoodsDto {
-
private String goodsNo;
+ @NotBlank(message = "商品名称不能为空")
private String goodsName;
private List<AddMallGoodsSkuDto> addMallGoodsSkuDtos;
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallGoodsService.java b/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallGoodsService.java
index 81b862c..d188de7 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallGoodsService.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallGoodsService.java
@@ -3,6 +3,7 @@
import cc.mrbird.febs.common.entity.FebsResponse;
import cc.mrbird.febs.common.entity.QueryRequest;
import cc.mrbird.febs.common.utils.MallUtils;
+import cc.mrbird.febs.common.utils.ValidateEntityUtils;
import cc.mrbird.febs.mall.conversion.MallGoodsConversion;
import cc.mrbird.febs.mall.dto.*;
import cc.mrbird.febs.mall.entity.*;
@@ -58,22 +59,10 @@
@Transactional
public FebsResponse addMallGoods(AddMallGoodsDto addMallGoodsDto) {
String goodsName = addMallGoodsDto.getGoodsName();
- if (StrUtil.isEmpty(goodsName)) {
- return new FebsResponse().fail().message("商品名称不能为空");
- }
- Integer mallGoodsByGoodsName = mallGoodsMapper.selectMallGoodsCountByGoodsName(goodsName);
- if (mallGoodsByGoodsName > 0) {
- return new FebsResponse().fail().message("商品名称不能重复");
- }
+ ValidateEntityUtils.ensureUnique(goodsName, MallGoods::getGoodsName, mallGoodsMapper::selectCount, "商品名称不能重复");
String goodsNo = MallUtils.getOrderNum("PT");
+ ValidateEntityUtils.ensureUnique(goodsNo, MallGoods::getGoodsNo, mallGoodsMapper::selectCount, "商品编号不能重复");
addMallGoodsDto.setGoodsNo(goodsNo);
- if (StrUtil.isEmpty(goodsNo)) {
- return new FebsResponse().fail().message("商品编号不能为空");
- }
- Integer mallGoodsByGoodsNo = mallGoodsMapper.selectMallGoodsCountByGoodsNo(goodsNo);
- if (mallGoodsByGoodsNo > 0) {
- return new FebsResponse().fail().message("商品编号不能重复");
- }
Integer carriageType = addMallGoodsDto.getCarriageType();
if (addMallGoodsDto.getGoodsType() == 1) {
if (1 == carriageType) {
@@ -83,13 +72,9 @@
}
} else {
Long carriageRuleId = addMallGoodsDto.getCarriageRuleId();
- MallCarriageRule mallCarriageRule = mallCarriageRuleMapper.selectById(carriageRuleId);
- if (ObjectUtil.isEmpty(mallCarriageRule)) {
- return new FebsResponse().fail().message("邮费模板不能为空");
- }
+ ValidateEntityUtils.ensureColumnValid(carriageRuleId, MallCarriageRule::getId, mallCarriageRuleMapper::selectOne, "邮费模板不能为空");
}
}
-
// 付费商品
if (addMallGoodsDto.getGoodsType() != 2) {
@@ -260,10 +245,7 @@
@Override
public FebsResponse upMallGoods(Long id) {
- MallGoods mallGoods = mallGoodsMapper.selectById(id);
- if (ObjectUtil.isEmpty(mallGoods)) {
- return new FebsResponse().fail().message("商品不存在,请刷新当前页面");
- }
+ MallGoods mallGoods = ValidateEntityUtils.ensureColumnReturnEntity(id,MallGoods::getId,mallGoodsMapper::selectOne,"商品不存在,请刷新当前页面");
mallGoods.setIsSale(MallGoods.ISSALE_STATUS_ENABLE);
mallGoodsMapper.updateById(mallGoods);
return new FebsResponse().success();
@@ -271,10 +253,7 @@
@Override
public FebsResponse downMallGoods(Long id) {
- MallGoods mallGoods = mallGoodsMapper.selectById(id);
- if (ObjectUtil.isEmpty(mallGoods)) {
- return new FebsResponse().fail().message("商品不存在,请刷新当前页面");
- }
+ MallGoods mallGoods = ValidateEntityUtils.ensureColumnReturnEntity(id,MallGoods::getId,mallGoodsMapper::selectOne,"商品不存在,请刷新当前页面");
mallGoods.setIsSale(MallGoods.ISSALE_STATUS_DISABLED);
mallGoodsMapper.updateById(mallGoods);
return new FebsResponse().success();
@@ -283,14 +262,8 @@
@Override
@Transactional
public FebsResponse delMallGoods(Long id) {
- MallGoods mallGoods = mallGoodsMapper.selectById(id);
- if (ObjectUtil.isEmpty(mallGoods)) {
- return new FebsResponse().fail().message("商品不存在,请刷新当前页面");
- }
- Integer isSale = mallGoods.getIsSale();
- if (MallGoods.ISSALE_STATUS_DISABLED != isSale) {
- return new FebsResponse().fail().message("请先下架该商品");
- }
+ MallGoods mallGoods = ValidateEntityUtils.ensureColumnReturnEntity(id,MallGoods::getId,mallGoodsMapper::selectOne,"商品不存在,请刷新当前页面");
+ ValidateEntityUtils.ensureEqual(mallGoods.getIsSale(), MallGoods.ISSALE_STATUS_DISABLED, "请先下架该商品");
mallGoodsStyleMapper.deleteByGoodsId(id);
mallGoodsSkuMapper.deleteByGoodsId(id);
@@ -598,10 +571,7 @@
@Override
public FebsResponse goodsHot(Long id) {
- MallGoods mallGoods = mallGoodsMapper.selectById(id);
- if (ObjectUtil.isEmpty(mallGoods)) {
- return new FebsResponse().fail().message("商品不存在,请刷新当前页面");
- }
+ MallGoods mallGoods = ValidateEntityUtils.ensureColumnReturnEntity(id,MallGoods::getId,mallGoodsMapper::selectOne,"商品不存在,请刷新当前页面");
mallGoods.setIsHot(MallGoods.ISHOT_STATE_YES);
mallGoodsMapper.updateById(mallGoods);
return new FebsResponse().success();
@@ -609,10 +579,7 @@
@Override
public FebsResponse goodsNotHot(Long id) {
- MallGoods mallGoods = mallGoodsMapper.selectById(id);
- if (ObjectUtil.isEmpty(mallGoods)) {
- return new FebsResponse().fail().message("商品不存在,请刷新当前页面");
- }
+ MallGoods mallGoods = ValidateEntityUtils.ensureColumnReturnEntity(id,MallGoods::getId,mallGoodsMapper::selectOne,"商品不存在,请刷新当前页面");
mallGoods.setIsHot(MallGoods.ISHOT_STATE_NO);
mallGoodsMapper.updateById(mallGoods);
return new FebsResponse().success();
@@ -658,10 +625,7 @@
@Override
@Transactional
public FebsResponse carriageRuleDelById(Long id) {
- MallCarriageRule mallCarriageRule = mallCarriageRuleMapper.selectById(id);
- if(ObjectUtil.isEmpty(mallCarriageRule)){
- return new FebsResponse().fail().message("操作失败");
- }
+ ValidateEntityUtils.ensureColumnValid(id, MallCarriageRule::getId, mallCarriageRuleMapper::selectOne, "模板不存在");
List<MallGoods> mallGoods = this.baseMapper.selectMallGoodsListQueryByRuleId(id);
if(CollUtil.isNotEmpty(mallGoods)){
StringBuffer goodsNameBuffer = new StringBuffer();
@@ -683,12 +647,7 @@
@Transactional
public FebsResponse carriageRuleAdd(AdminCarriageRuleAddDto adminCarriageRuleAddDto) {
String ruleName = adminCarriageRuleAddDto.getRuleName();
- QueryWrapper<MallCarriageRule> objectQueryWrapper = new QueryWrapper<>();
- objectQueryWrapper.eq("name",ruleName);
- List<MallCarriageRule> mallCarriageRules = mallCarriageRuleMapper.selectList(objectQueryWrapper);
- if(CollUtil.isNotEmpty(mallCarriageRules)){
- return new FebsResponse().fail().message("标题不能重复");
- }
+ ValidateEntityUtils.ensureUnique(ruleName,MallCarriageRule::getName,mallCarriageRuleMapper::selectCount,"标题不能重复");
MallCarriageRule mallCarriageRule = new MallCarriageRule();
mallCarriageRule.setName(ruleName);
@@ -775,10 +734,7 @@
@Transactional
public FebsResponse carriageRuleUpdate(AdminCarriageRuleUpdateDto adminCarriageRuleUpdateDto) {
Long id = adminCarriageRuleUpdateDto.getId();
- MallCarriageRule mallCarriageRule = mallCarriageRuleMapper.selectById(id);
- if(ObjectUtil.isEmpty(mallCarriageRule)){
- return new FebsResponse().fail().message("运费模板不存在");
- }
+ MallCarriageRule mallCarriageRule = ValidateEntityUtils.ensureColumnReturnEntity(id,MallCarriageRule::getId,mallCarriageRuleMapper::selectOne,"运费模板不存在");
List<MallGoods> mallGoods = this.baseMapper.selectMallGoodsListQueryByRuleIdAndIsSale(id,MallGoods.ISHOT_STATE_YES);
if(CollUtil.isNotEmpty(mallGoods)){
@@ -854,14 +810,7 @@
@Override
public FebsResponse couponRuleAdd(CouponRuleAddDto couponRuleAddDto) {
String name = couponRuleAddDto.getName();
- List<MallGoodsCoupon> mallGoodsCoupons = mallGoodsCouponMapper.selectList(
- new LambdaQueryWrapper<MallGoodsCoupon>()
- .select(MallGoodsCoupon::getId)
- .eq(MallGoodsCoupon::getName,name)
- );
- if(CollUtil.isNotEmpty(mallGoodsCoupons)){
- return new FebsResponse().fail().message("优惠卷名称重复了");
- }
+ ValidateEntityUtils.ensureUnique(name,MallGoodsCoupon::getName,mallGoodsCouponMapper::selectCount,"优惠卷名称重复了");
MallGoodsCoupon mallGoodsCoupon = new MallGoodsCoupon();
mallGoodsCoupon.setName(name);
@@ -895,24 +844,15 @@
@Override
public FebsResponse couponRuleDel(Long id) {
- MallGoodsCoupon mallGoodsCoupon = mallGoodsCouponMapper.selectById(id);
- if (ObjectUtil.isEmpty(mallGoodsCoupon)) {
- return new FebsResponse().fail().message("优惠卷不存在,请刷新当前页面");
- }
- Integer state = mallGoodsCoupon.getState();
- if(2 == state){
- return new FebsResponse().fail().message("请先下架优惠卷");
- }
+ MallGoodsCoupon mallGoodsCoupon = ValidateEntityUtils.ensureColumnReturnEntity(id, MallGoodsCoupon::getId, mallGoodsCouponMapper::selectOne, "优惠卷不存在");
+ ValidateEntityUtils.ensureNotEqual(mallGoodsCoupon.getState(),2,"优惠卷已上架,请先下架");
mallGoodsCouponMapper.deleteById(id);
return new FebsResponse().success();
}
@Override
public FebsResponse upCoupon(Long id) {
- MallGoodsCoupon mallGoodsCoupon = mallGoodsCouponMapper.selectById(id);
- if (ObjectUtil.isEmpty(mallGoodsCoupon)) {
- return new FebsResponse().fail().message("优惠卷不存在,请刷新当前页面");
- }
+ MallGoodsCoupon mallGoodsCoupon = ValidateEntityUtils.ensureColumnReturnEntity(id, MallGoodsCoupon::getId, mallGoodsCouponMapper::selectOne, "优惠卷不存在");
mallGoodsCoupon.setState(2);
mallGoodsCouponMapper.updateById(mallGoodsCoupon);
return new FebsResponse().success();
@@ -920,10 +860,7 @@
@Override
public FebsResponse downCoupon(Long id) {
- MallGoodsCoupon mallGoodsCoupon = mallGoodsCouponMapper.selectById(id);
- if (ObjectUtil.isEmpty(mallGoodsCoupon)) {
- return new FebsResponse().fail().message("优惠卷不存在,请刷新当前页面");
- }
+ MallGoodsCoupon mallGoodsCoupon = ValidateEntityUtils.ensureColumnReturnEntity(id, MallGoodsCoupon::getId, mallGoodsCouponMapper::selectOne, "优惠卷不存在");
mallGoodsCoupon.setState(1);
mallGoodsCouponMapper.updateById(mallGoodsCoupon);
return new FebsResponse().success().message("操作成功");
@@ -940,14 +877,9 @@
@Override
public FebsResponse couponUpdate(AdminMallGoodsCouponVo adminMallGoodsCouponVo) {
Long id = adminMallGoodsCouponVo.getId();
- MallGoodsCoupon mallGoodsCoupon = mallGoodsCouponMapper.selectById(id);
- if (ObjectUtil.isEmpty(mallGoodsCoupon)) {
- return new FebsResponse().fail().message("优惠卷不存在,请刷新当前页面");
- }
- Integer state = mallGoodsCoupon.getState();
- if(2 == state){
- return new FebsResponse().fail().message("请先下架优惠卷");
- }
+ MallGoodsCoupon mallGoodsCoupon = ValidateEntityUtils.ensureColumnReturnEntity(id, MallGoodsCoupon::getId, mallGoodsCouponMapper::selectOne, "优惠卷不存在");
+ ValidateEntityUtils.ensureNotEqual(mallGoodsCoupon.getState(),2,"优惠卷已上架,请先下架");
+
mallGoodsCoupon.setName(adminMallGoodsCouponVo.getName());
mallGoodsCoupon.setExpireDay(adminMallGoodsCouponVo.getExpireDay());
mallGoodsCoupon.setCostAmount(adminMallGoodsCouponVo.getCostAmount());
--
Gitblit v1.9.1