feature(uniapp商品): 代码调整

pull/2/head
luowenfeng 2022-08-25 17:10:26 +08:00
parent 0bc2ef1d39
commit 4a39f2d9f8
5 changed files with 70 additions and 77 deletions

View File

@ -214,21 +214,26 @@ DROP TABLE IF EXISTS `product_sku`;
CREATE TABLE `product_sku` ( CREATE TABLE `product_sku` (
`id` bigint NOT NULL AUTO_INCREMENT COMMENT '', `id` bigint NOT NULL AUTO_INCREMENT COMMENT '',
`spu_id` bigint NOT NULL COMMENT 'spu', `spu_id` bigint NOT NULL COMMENT 'spu',
`properties` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '-json [{propertId: , valueId: }, {propertId: , valueId: }]', `tenant_id` bigint NOT NULL DEFAULT '0' COMMENT '',
`price` int NOT NULL DEFAULT -1 COMMENT '', `name` varchar(128) DEFAULT NULL COMMENT ' SKU ',
`original_price` int NOT NULL DEFAULT -1 COMMENT ' ', `properties` varchar(128) DEFAULT NULL COMMENT '-json [{propertId: , valueId: }, {propertId: , valueId: }]',
`cost_price` int NOT NULL DEFAULT -1 COMMENT ' ', `price` int NOT NULL DEFAULT '-1' COMMENT '',
`bar_code` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '', `market_price` int DEFAULT NULL COMMENT '',
`pic_url` varchar(128) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '', `cost_price` int NOT NULL DEFAULT '-1' COMMENT ' ',
`status` tinyint NULL DEFAULT NULL COMMENT ' 0- 1-', `pic_url` varchar(128) NOT NULL COMMENT '',
`create_time` datetime NULL DEFAULT CURRENT_TIMESTAMP COMMENT '', `stock` int DEFAULT NULL COMMENT '',
`update_time` datetime NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '', `warn_stock` int DEFAULT NULL COMMENT '',
`creator` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '', `volume` double DEFAULT NULL COMMENT '',
`updater` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '', `weight` double DEFAULT NULL COMMENT '',
`tenant_id` bigint NOT NULL DEFAULT 0 COMMENT '', `bar_code` varchar(64) DEFAULT NULL COMMENT '',
`status` tinyint DEFAULT NULL COMMENT ' 0- 1-',
`create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '',
`update_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '',
`creator` varchar(64) DEFAULT NULL COMMENT '',
`updater` double(64,0) DEFAULT NULL COMMENT '',
`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '', `deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '',
PRIMARY KEY (`id`) USING BTREE PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = 'sku'; ) ENGINE=InnoDB COMMENT='sku';
-- ---------------------------- -- ----------------------------
-- Records of product_sku -- Records of product_sku
@ -242,24 +247,33 @@ COMMIT;
DROP TABLE IF EXISTS `product_spu`; DROP TABLE IF EXISTS `product_spu`;
CREATE TABLE `product_spu` ( CREATE TABLE `product_spu` (
`id` bigint NOT NULL AUTO_INCREMENT COMMENT '', `id` bigint NOT NULL AUTO_INCREMENT COMMENT '',
`name` varchar(128) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '', `tenant_id` bigint NOT NULL DEFAULT '0' COMMENT '',
`sell_point` varchar(128) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '', `brand_id` int DEFAULT NULL COMMENT '',
`description` text CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '',
`category_id` bigint NOT NULL COMMENT 'id', `category_id` bigint NOT NULL COMMENT 'id',
`pic_urls` varchar(1024) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '' COMMENT '\n *\n * \n 15', `spec_type` int NOT NULL COMMENT '0 1 ',
`sort` int NOT NULL DEFAULT 0 COMMENT '', `code` varchar(128) DEFAULT NULL COMMENT '',
`like_count` int NULL DEFAULT NULL COMMENT '', `name` varchar(128) NOT NULL COMMENT '',
`price` int NULL DEFAULT NULL COMMENT ' 使', `sell_point` varchar(128) DEFAULT NULL COMMENT '',
`quantity` int NULL DEFAULT NULL COMMENT '', `description` text COMMENT '',
`status` bit(1) NULL DEFAULT NULL COMMENT ' 0 1 ', `pic_urls` varchar(1024) DEFAULT '' COMMENT '\n \n 15',
`create_time` datetime NULL DEFAULT CURRENT_TIMESTAMP COMMENT '', `video_url` varchar(128) DEFAULT NULL COMMENT '',
`update_time` datetime NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '', `market_price` int DEFAULT NULL COMMENT '使',
`creator` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '', `min_price` int DEFAULT NULL COMMENT '使',
`updater` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '', `max_price` int DEFAULT NULL COMMENT '使',
`tenant_id` bigint NOT NULL DEFAULT 0 COMMENT '', `total_stock` int NOT NULL DEFAULT '0' COMMENT '',
`show_stock` int DEFAULT '0' COMMENT '',
`sales_count` int DEFAULT '0' COMMENT '',
`virtual_sales_count` int DEFAULT '0' COMMENT '',
`click_count` int DEFAULT '0' COMMENT '',
`status` bit(1) DEFAULT NULL COMMENT ' 0 1 -1 ',
`sort` int NOT NULL DEFAULT '0' COMMENT '',
`create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '',
`update_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '',
`creator` varchar(64) DEFAULT NULL COMMENT '',
`updater` varchar(64) DEFAULT NULL COMMENT '',
`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '', `deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '',
PRIMARY KEY (`id`) USING BTREE PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = 'spu'; ) ENGINE=InnoDB COMMENT='spu';
-- ---------------------------- -- ----------------------------
-- Records of product_spu -- Records of product_spu
@ -299,26 +313,3 @@ INSERT INTO `ruoyi-vue-pro`.`system_menu` (`id`, `name`, `permission`, `type`, `
INSERT INTO `ruoyi-vue-pro`.`system_menu` (`id`, `name`, `permission`, `type`, `sort`, `parent_id`, `path`, `icon`, `component`, `status`, `visible`, `keep_alive`, `creator`, `create_time`, `updater`, `update_time`, `deleted`) VALUES (2028, 'Banner', 'market:banner:update', 3, 3, 2025, '', '', '', 0, b'1', b'1', '', '2022-08-01 14:56:14', '', '2022-08-01 14:56:14', b'0'); INSERT INTO `ruoyi-vue-pro`.`system_menu` (`id`, `name`, `permission`, `type`, `sort`, `parent_id`, `path`, `icon`, `component`, `status`, `visible`, `keep_alive`, `creator`, `create_time`, `updater`, `update_time`, `deleted`) VALUES (2028, 'Banner', 'market:banner:update', 3, 3, 2025, '', '', '', 0, b'1', b'1', '', '2022-08-01 14:56:14', '', '2022-08-01 14:56:14', b'0');
INSERT INTO `ruoyi-vue-pro`.`system_menu` (`id`, `name`, `permission`, `type`, `sort`, `parent_id`, `path`, `icon`, `component`, `status`, `visible`, `keep_alive`, `creator`, `create_time`, `updater`, `update_time`, `deleted`) VALUES (2029, 'Banner', 'market:banner:delete', 3, 4, 2025, '', '', '', 0, b'1', b'1', '', '2022-08-01 14:56:14', '', '2022-08-01 14:56:14', b'0'); INSERT INTO `ruoyi-vue-pro`.`system_menu` (`id`, `name`, `permission`, `type`, `sort`, `parent_id`, `path`, `icon`, `component`, `status`, `visible`, `keep_alive`, `creator`, `create_time`, `updater`, `update_time`, `deleted`) VALUES (2029, 'Banner', 'market:banner:delete', 3, 4, 2025, '', '', '', 0, b'1', b'1', '', '2022-08-01 14:56:14', '', '2022-08-01 14:56:14', b'0');
alter table product_spu add `code` varchar(128) COMMENT '';
alter table product_spu add total_stock int COMMENT '';
alter table product_spu add warn_stock int COMMENT '';
alter table product_spu add show_stock int COMMENT '';
alter table product_spu add sales_count int COMMENT '';
alter table product_spu add virtual_sales_count int COMMENT '';
alter table product_spu add click_count int COMMENT '';
alter table product_spu add banner_url varchar(128) COMMENT '';
alter table product_spu add spec_type int COMMENT '';
alter table product_spu add brand_id int COMMENT '';
alter table product_spu add video_url varchar(128) COMMENT '';
alter table product_spu add min_price int COMMENT '使';
alter table product_spu add max_price int COMMENT '使';
alter table product_spu add market_price int COMMENT '使';
alter table product_sku add `name` varchar(128) COMMENT ' SKU ';
alter table product_sku add `stock` int COMMENT '';
alter table product_sku add `weight` double COMMENT '';
alter table product_sku add `volume` double COMMENT '';
alter table product_sku DROP `original_price`;

View File

@ -7,6 +7,7 @@ import cn.iocoder.yudao.module.product.controller.admin.sku.vo.ProductSkuPageReq
import cn.iocoder.yudao.module.product.dal.dataobject.sku.ProductSkuDO; import cn.iocoder.yudao.module.product.dal.dataobject.sku.ProductSkuDO;
import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Mapper;
import java.util.Collections;
import java.util.List; import java.util.List;
/** /**
@ -38,6 +39,10 @@ public interface ProductSkuMapper extends BaseMapperX<ProductSkuDO> {
.inIfPresent(ProductSkuDO::getSpuId, spuIds)); .inIfPresent(ProductSkuDO::getSpuId, spuIds));
} }
default List<ProductSkuDO> selectBySpuId(Long spuIds) {
return selectBySpuIds(Collections.singletonList(spuIds));
}
default void deleteBySpuId(Long spuId) { default void deleteBySpuId(Long spuId) {
// TODO @franky直接 delete(new XXX) 即可,更简洁一些 // TODO @franky直接 delete(new XXX) 即可,更简洁一些
LambdaQueryWrapperX<ProductSkuDO> lambdaQueryWrapperX = new LambdaQueryWrapperX<ProductSkuDO>() LambdaQueryWrapperX<ProductSkuDO> lambdaQueryWrapperX = new LambdaQueryWrapperX<ProductSkuDO>()

View File

@ -1,5 +1,6 @@
package cn.iocoder.yudao.module.product.service.sku; package cn.iocoder.yudao.module.product.service.sku;
import cn.hutool.core.collection.CollectionUtil;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.util.collection.CollectionUtils; import cn.iocoder.yudao.framework.common.util.collection.CollectionUtils;
import cn.iocoder.yudao.module.product.controller.admin.property.vo.ProductPropertyRespVO; import cn.iocoder.yudao.module.product.controller.admin.property.vo.ProductPropertyRespVO;
@ -156,10 +157,8 @@ public class ProductSkuServiceImpl implements ProductSkuService {
@Transactional @Transactional
public void updateProductSkus(Long spuId, List<ProductSkuCreateOrUpdateReqVO> skus) { public void updateProductSkus(Long spuId, List<ProductSkuCreateOrUpdateReqVO> skus) {
// 查询 spu 下已经存在的 sku 的集合 // 查询 spu 下已经存在的 sku 的集合
// TODO @luowenfengselectListBySpuId 搞个 List<ProductSkuDO> existsSkus = productSkuMapper.selectBySpuId(spuId);
List<ProductSkuDO> existsSkus = productSkuMapper.selectBySpuIds(Collections.singletonList(spuId)); Map<Long, ProductSkuDO> existsSkuMap = CollectionUtils.convertMap(existsSkus, ProductSkuDO::getId);
// TODO @franky使用 CollUtils 即可
Map<Long, ProductSkuDO> existsSkuMap = existsSkus.stream().collect(Collectors.toMap(ProductSkuDO::getId, p -> p));
// 拆分三个集合,新插入的、需要更新的、需要删除的 // 拆分三个集合,新插入的、需要更新的、需要删除的
List<ProductSkuDO> insertSkus = new ArrayList<>(); List<ProductSkuDO> insertSkus = new ArrayList<>();
@ -170,8 +169,7 @@ public class ProductSkuServiceImpl implements ProductSkuService {
List<ProductSkuDO> allUpdateSkus = ProductSkuConvert.INSTANCE.convertSkuDOList(skus); List<ProductSkuDO> allUpdateSkus = ProductSkuConvert.INSTANCE.convertSkuDOList(skus);
allUpdateSkus.forEach(p -> { allUpdateSkus.forEach(p -> {
if (p.getId() != null) { if (p.getId() != null) {
// TODO @luowenfengcontains if (existsSkuMap.containsKey(p.getId())) {
if (existsSkuMap.get(p.getId()) != null) {
updateSkus.add(p); updateSkus.add(p);
return; return;
} }
@ -182,8 +180,7 @@ public class ProductSkuServiceImpl implements ProductSkuService {
insertSkus.add(p); insertSkus.add(p);
}); });
// TODO @luowenfeng使用 CollUtil.isNotEmpty 判断 if (CollectionUtil.isNotEmpty(insertSkus)) {
if (insertSkus.size() > 0) {
productSkuMapper.insertBatch(insertSkus); productSkuMapper.insertBatch(insertSkus);
} }
if (updateSkus.size() > 0) { if (updateSkus.size() > 0) {

View File

@ -60,7 +60,7 @@ public class ProductSpuServiceImpl implements ProductSpuService {
public Long createProductSpu(ProductSpuCreateReqVO createReqVO) { public Long createProductSpu(ProductSpuCreateReqVO createReqVO) {
// 校验分类 // 校验分类
categoryService.validateProductCategory(createReqVO.getCategoryId()); categoryService.validateProductCategory(createReqVO.getCategoryId());
// TODO @luowenfeng:校验品牌 // TODO @:校验品牌
// 校验SKU // 校验SKU
List<ProductSkuCreateOrUpdateReqVO> skuCreateReqList = createReqVO.getSkus(); List<ProductSkuCreateOrUpdateReqVO> skuCreateReqList = createReqVO.getSkus();

View File

@ -50,7 +50,7 @@
"quickapp" : {}, "quickapp" : {},
/* */ /* */
"mp-weixin" : { "mp-weixin" : {
"appid" : "", "appid" : "wx48d7c38b46f2e81c",
"setting" : { "setting" : {
"urlCheck" : false "urlCheck" : false
}, },