diff --git a/sql/mall.sql b/sql/mall.sql index c3945a1fe..7b3d8ce5b 100644 --- a/sql/mall.sql +++ b/sql/mall.sql @@ -171,7 +171,7 @@ VALUES ('商品导出', 'product:spu:export', 3, 5, @parentId, '', '', '', 0); drop table if exists product_property; create table product_property ( - id bigint comment '主键', + id bigint NOT NULL AUTO_INCREMENT comment '主键', name varchar(64) comment '规格名称', status tinyint comment '状态: 0 开启 ,1 禁用', create_time datetime default current_timestamp comment '创建时间', @@ -179,7 +179,7 @@ create table product_property creator varchar(64) comment '创建人', updater varchar(64) comment '更新人', tenant_id bigint NOT NULL DEFAULT '0' COMMENT '租户编号', - deleted bit(1) comment '状态', + deleted bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除', primary key (id), key idx_name ( name (32)) comment '规格名称索引' ) comment '规格名称' character set utf8mb4 @@ -189,7 +189,7 @@ create table product_property drop table if exists product_property_value; create table product_property_value ( - id int comment '主键', + id bigint NOT NULL AUTO_INCREMENT COMMENT '主键', property_id bigint comment '规格键id', name varchar(128) comment '规格值名字', status tinyint comment '状态: 1 开启 ,2 禁用', @@ -198,7 +198,7 @@ create table product_property_value creator varchar(64) comment '创建人', updater varchar(64) comment '更新人', tenant_id bigint NOT NULL DEFAULT '0' COMMENT '租户编号', - deleted bit(1) comment '状态', + deleted bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除', primary key (id) ) comment '规格值' character set utf8mb4 collate utf8mb4_general_ci; @@ -207,7 +207,7 @@ create table product_property_value drop table if exists product_spu; create table product_spu ( - id int comment '主键', + id bigint NOT NULL AUTO_INCREMENT COMMENT '主键', name varchar(128) comment '商品名称', sell_point varchar(128) not null comment '卖点', description text not null comment '描述', @@ -223,7 +223,7 @@ create table product_spu creator varchar(64) comment '创建人', updater varchar(64) comment '更新人', tenant_id bigint NOT NULL DEFAULT '0' COMMENT '租户编号', - deleted bit(1) comment '状态', + deleted bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除', primary key (id) ) comment '商品spu' character set utf8mb4 collate utf8mb4_general_ci; @@ -233,7 +233,7 @@ create table product_spu drop table if exists product_sku; create table product_sku ( - id int comment '主键', + id bigint NOT NULL AUTO_INCREMENT COMMENT '主键', spu_id bigint not null comment 'spu编号', properties varchar(64) not null comment '规格值数组-json格式, [{propertId: , valueId: }, {propertId: , valueId: }]', price int not null DEFAULT -1 comment '销售价格,单位:分', @@ -247,7 +247,7 @@ create table product_sku creator varchar(64) comment '创建人', updater varchar(64) comment '更新人', tenant_id bigint NOT NULL DEFAULT '0' COMMENT '租户编号', - deleted bit(1) comment '状态', + deleted bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除', primary key (id) ) comment '商品sku' character set utf8mb4 collate utf8mb4_general_ci; diff --git a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/property/ProductPropertyController.java b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/property/ProductPropertyController.java index c81cce984..f1d31acab 100644 --- a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/property/ProductPropertyController.java +++ b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/property/ProductPropertyController.java @@ -63,8 +63,7 @@ public class ProductPropertyController { @ApiImplicitParam(name = "id", value = "编号", required = true, example = "1024", dataTypeClass = Long.class) @PreAuthorize("@ss.hasPermission('product:property:query')") public CommonResult getProperty(@RequestParam("id") Long id) { - ProductPropertyDO property = productPropertyService.getProperty(id); - return success(ProductPropertyConvert.INSTANCE.convert(property)); + return success(productPropertyService.getPropertyResp(id)); } @GetMapping("/list") @@ -80,8 +79,7 @@ public class ProductPropertyController { @ApiOperation("获得规格名称分页") @PreAuthorize("@ss.hasPermission('product:property:query')") public CommonResult> getPropertyPage(@Valid ProductPropertyPageReqVO pageVO) { - PageResult pageResult = productPropertyService.getPropertyPage(pageVO); - return success(ProductPropertyConvert.INSTANCE.convertPage(pageResult)); + return success(productPropertyService.getPropertyListPage(pageVO)); } @GetMapping("/export-excel") diff --git a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/property/vo/ProductPropertyCreateReqVO.java b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/property/vo/ProductPropertyCreateReqVO.java index 560771623..d29f7aa2f 100644 --- a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/property/vo/ProductPropertyCreateReqVO.java +++ b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/property/vo/ProductPropertyCreateReqVO.java @@ -1,12 +1,20 @@ package cn.iocoder.yudao.module.product.controller.admin.property.vo; +import cn.iocoder.yudao.module.product.controller.admin.propertyvalue.vo.PropertyValueCreateReqVO; import lombok.*; import io.swagger.annotations.*; +import javax.validation.constraints.NotNull; +import java.util.List; + @ApiModel("管理后台 - 规格名称创建 Request VO") @Data @EqualsAndHashCode(callSuper = true) @ToString(callSuper = true) public class ProductPropertyCreateReqVO extends ProductPropertyBaseVO { + @ApiModelProperty(value = "属性值") + @NotNull(message = "属性值不能为空") + List propertyValueList; + } diff --git a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/property/vo/ProductPropertyRespVO.java b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/property/vo/ProductPropertyRespVO.java index 2ef5c6efd..ca85f4d93 100644 --- a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/property/vo/ProductPropertyRespVO.java +++ b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/property/vo/ProductPropertyRespVO.java @@ -17,6 +17,7 @@ public class ProductPropertyRespVO extends ProductPropertyBaseVO { @ApiModelProperty(value = "创建时间") private Date createTime; - private List propertyValueRespVOList; + @ApiModelProperty(value = "属性值") + private List propertyValueList; } diff --git a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/property/vo/ProductPropertyUpdateReqVO.java b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/property/vo/ProductPropertyUpdateReqVO.java index f53d200d2..6e077829e 100644 --- a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/property/vo/ProductPropertyUpdateReqVO.java +++ b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/property/vo/ProductPropertyUpdateReqVO.java @@ -1,8 +1,10 @@ package cn.iocoder.yudao.module.product.controller.admin.property.vo; +import cn.iocoder.yudao.module.product.controller.admin.propertyvalue.vo.PropertyValueCreateReqVO; import lombok.*; import io.swagger.annotations.*; import javax.validation.constraints.*; +import java.util.List; @ApiModel("管理后台 - 规格名称更新 Request VO") @Data @@ -14,4 +16,8 @@ public class ProductPropertyUpdateReqVO extends ProductPropertyBaseVO { @NotNull(message = "主键不能为空") private Long id; + @ApiModelProperty(value = "属性值") + @NotNull(message = "属性值不能为空") + List propertyValueList; + } diff --git a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/propertyvalue/PropertyValueController.java b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/propertyvalue/PropertyValueController.java deleted file mode 100755 index 78404e507..000000000 --- a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/controller/admin/propertyvalue/PropertyValueController.java +++ /dev/null @@ -1,100 +0,0 @@ -package cn.iocoder.yudao.module.product.controller.admin.propertyvalue; - -import org.springframework.web.bind.annotation.*; -import javax.annotation.Resource; -import org.springframework.validation.annotation.Validated; -import org.springframework.security.access.prepost.PreAuthorize; -import io.swagger.annotations.*; - -import javax.validation.constraints.*; -import javax.validation.*; -import javax.servlet.http.*; -import java.util.*; -import java.io.IOException; - -import cn.iocoder.yudao.framework.common.pojo.PageResult; -import cn.iocoder.yudao.framework.common.pojo.CommonResult; -import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; - -import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; - -import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog; -import static cn.iocoder.yudao.framework.operatelog.core.enums.OperateTypeEnum.*; - -import cn.iocoder.yudao.module.product.controller.admin.propertyvalue.vo.*; -import cn.iocoder.yudao.module.product.dal.dataobject.propertyvalue.PropertyValueDO; -import cn.iocoder.yudao.module.product.convert.propertyvalue.PropertyValueConvert; -import cn.iocoder.yudao.module.product.service.propertyvalue.PropertyValueService; - -@Api(tags = "管理后台 - 规格值") -@RestController -@RequestMapping("/product/property-value") -@Validated -public class PropertyValueController { - - @Resource - private PropertyValueService propertyValueService; - - @PostMapping("/create") - @ApiOperation("创建规格值") - @PreAuthorize("@ss.hasPermission('product:property-value:create')") - public CommonResult createPropertyValue(@Valid @RequestBody PropertyValueCreateReqVO createReqVO) { - return success(propertyValueService.createPropertyValue(createReqVO)); - } - - @PutMapping("/update") - @ApiOperation("更新规格值") - @PreAuthorize("@ss.hasPermission('product:property-value:update')") - public CommonResult updatePropertyValue(@Valid @RequestBody PropertyValueUpdateReqVO updateReqVO) { - propertyValueService.updatePropertyValue(updateReqVO); - return success(true); - } - - @DeleteMapping("/delete") - @ApiOperation("删除规格值") - @ApiImplicitParam(name = "id", value = "编号", required = true, dataTypeClass = Integer.class) - @PreAuthorize("@ss.hasPermission('product:property-value:delete')") - public CommonResult deletePropertyValue(@RequestParam("id") Integer id) { - propertyValueService.deletePropertyValue(id); - return success(true); - } - - @GetMapping("/get") - @ApiOperation("获得规格值") - @ApiImplicitParam(name = "id", value = "编号", required = true, example = "1024", dataTypeClass = Integer.class) - @PreAuthorize("@ss.hasPermission('product:property-value:query')") - public CommonResult getPropertyValue(@RequestParam("id") Integer id) { - PropertyValueDO propertyValue = propertyValueService.getPropertyValue(id); - return success(PropertyValueConvert.INSTANCE.convert(propertyValue)); - } - - @GetMapping("/list") - @ApiOperation("获得规格值列表") - @ApiImplicitParam(name = "ids", value = "编号列表", required = true, example = "1024,2048", dataTypeClass = List.class) - @PreAuthorize("@ss.hasPermission('product:property-value:query')") - public CommonResult> getPropertyValueList(@RequestParam("ids") Collection ids) { - List list = propertyValueService.getPropertyValueList(ids); - return success(PropertyValueConvert.INSTANCE.convertList(list)); - } - - @GetMapping("/page") - @ApiOperation("获得规格值分页") - @PreAuthorize("@ss.hasPermission('product:property-value:query')") - public CommonResult> getPropertyValuePage(@Valid PropertyValuePageReqVO pageVO) { - PageResult pageResult = propertyValueService.getPropertyValuePage(pageVO); - return success(PropertyValueConvert.INSTANCE.convertPage(pageResult)); - } - - @GetMapping("/export-excel") - @ApiOperation("导出规格值 Excel") - @PreAuthorize("@ss.hasPermission('product:property-value:export')") - @OperateLog(type = EXPORT) - public void exportPropertyValueExcel(@Valid PropertyValueExportReqVO exportReqVO, - HttpServletResponse response) throws IOException { - List list = propertyValueService.getPropertyValueList(exportReqVO); - // 导出 Excel - List datas = PropertyValueConvert.INSTANCE.convertList02(list); - ExcelUtils.write(response, "规格值.xls", "数据", PropertyValueExcelVO.class, datas); - } - -} diff --git a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/convert/propertyvalue/PropertyValueConvert.java b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/convert/propertyvalue/PropertyValueConvert.java index 58ec93069..7886eab85 100755 --- a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/convert/propertyvalue/PropertyValueConvert.java +++ b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/convert/propertyvalue/PropertyValueConvert.java @@ -31,4 +31,6 @@ public interface PropertyValueConvert { List convertList02(List list); + List convertList03(List list); + } diff --git a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/dal/mysql/propertyvalue/PropertyValueMapper.java b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/dal/mysql/propertyvalue/PropertyValueMapper.java index 305541783..b281450f0 100755 --- a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/dal/mysql/propertyvalue/PropertyValueMapper.java +++ b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/dal/mysql/propertyvalue/PropertyValueMapper.java @@ -35,4 +35,14 @@ public interface PropertyValueMapper extends BaseMapperX { .orderByDesc(PropertyValueDO::getId)); } + default List getPropertyValueListByPropertyId(List propertyIds){ + return selectList(new LambdaQueryWrapperX() + .inIfPresent(PropertyValueDO::getPropertyId, propertyIds)); + } + + default void deletePropertyValueByPropertyId(Long propertyId){ + LambdaQueryWrapperX queryWrapperX = new LambdaQueryWrapperX<>(); + queryWrapperX.eq(PropertyValueDO::getPropertyId, propertyId).eq(PropertyValueDO::getDeleted, false); + delete(queryWrapperX); + } } diff --git a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/service/property/ProductPropertyService.java b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/service/property/ProductPropertyService.java index eb02796ce..ec2622af5 100644 --- a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/service/property/ProductPropertyService.java +++ b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/service/property/ProductPropertyService.java @@ -67,4 +67,13 @@ public interface ProductPropertyService { */ List getPropertyList(ProductPropertyExportReqVO exportReqVO); + /** + * 获取属性及属性值列表 分页 + * @param pageReqVO + * @return + */ + PageResult getPropertyListPage(ProductPropertyPageReqVO pageReqVO); + + ProductPropertyRespVO getPropertyResp(Long id); + } diff --git a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/service/property/ProductPropertyServiceImpl.java b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/service/property/ProductPropertyServiceImpl.java index cdddd3ce4..3990855b3 100644 --- a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/service/property/ProductPropertyServiceImpl.java +++ b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/service/property/ProductPropertyServiceImpl.java @@ -4,15 +4,23 @@ import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.module.product.controller.admin.property.vo.*; import cn.iocoder.yudao.module.product.controller.admin.property.vo.ProductPropertyCreateReqVO; import cn.iocoder.yudao.module.product.controller.admin.property.vo.ProductPropertyUpdateReqVO; +import cn.iocoder.yudao.module.product.controller.admin.propertyvalue.vo.PropertyValueCreateReqVO; +import cn.iocoder.yudao.module.product.controller.admin.propertyvalue.vo.PropertyValueRespVO; import cn.iocoder.yudao.module.product.convert.property.ProductPropertyConvert; +import cn.iocoder.yudao.module.product.convert.propertyvalue.PropertyValueConvert; import cn.iocoder.yudao.module.product.dal.dataobject.property.ProductPropertyDO; +import cn.iocoder.yudao.module.product.dal.dataobject.propertyvalue.PropertyValueDO; import cn.iocoder.yudao.module.product.dal.mysql.property.ProductPropertyMapper; +import cn.iocoder.yudao.module.product.service.propertyvalue.PropertyValueService; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; import org.springframework.validation.annotation.Validated; import javax.annotation.Resource; +import java.util.Arrays; import java.util.Collection; import java.util.List; +import java.util.stream.Collectors; import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception; import static cn.iocoder.yudao.module.product.enums.ErrorCodeConstants.PROPERTY_NOT_EXISTS; @@ -29,22 +37,39 @@ public class ProductPropertyServiceImpl implements ProductPropertyService { @Resource private ProductPropertyMapper productPropertyMapper; + @Resource + private PropertyValueService propertyValueService; + @Override + @Transactional(rollbackFor = Exception.class) public Long createProperty(ProductPropertyCreateReqVO createReqVO) { // 插入 ProductPropertyDO property = ProductPropertyConvert.INSTANCE.convert(createReqVO); productPropertyMapper.insert(property); + + //插入属性值 + List propertyValueList = createReqVO.getPropertyValueList(); + List propertyValueDOList = PropertyValueConvert.INSTANCE.convertList03(propertyValueList); + propertyValueDOList.stream().forEach(x-> x.setPropertyId(property.getId())); + propertyValueService.batchInsert(propertyValueDOList); // 返回 return property.getId(); } @Override + @Transactional(rollbackFor = Exception.class) public void updateProperty(ProductPropertyUpdateReqVO updateReqVO) { // 校验存在 this.validatePropertyExists(updateReqVO.getId()); // 更新 ProductPropertyDO updateObj = ProductPropertyConvert.INSTANCE.convert(updateReqVO); productPropertyMapper.updateById(updateObj); + //更新属性值,先删后加 + propertyValueService.deletePropertyValueByPropertyId(updateReqVO.getId()); + List propertyValueList = updateReqVO.getPropertyValueList(); + List propertyValueDOList = PropertyValueConvert.INSTANCE.convertList03(propertyValueList); + propertyValueDOList.stream().forEach(x-> x.setPropertyId(updateReqVO.getId())); + propertyValueService.batchInsert(propertyValueDOList); } @Override @@ -53,6 +78,8 @@ public class ProductPropertyServiceImpl implements ProductPropertyService { this.validatePropertyExists(id); // 删除 productPropertyMapper.deleteById(id); + //同步删除属性值 + propertyValueService.deletePropertyValueByPropertyId(id); } private void validatePropertyExists(Long id) { @@ -81,4 +108,36 @@ public class ProductPropertyServiceImpl implements ProductPropertyService { return productPropertyMapper.selectList(exportReqVO); } + @Override + public PageResult getPropertyListPage(ProductPropertyPageReqVO pageReqVO) { + //获取属性列表 + PageResult pageResult = productPropertyMapper.selectPage(pageReqVO); + PageResult propertyRespVOPageResult = ProductPropertyConvert.INSTANCE.convertPage(pageResult); + List propertyIds = propertyRespVOPageResult.getList().stream().map(x -> x.getId()).collect(Collectors.toList()); + + //获取属性值列表 + List propertyValueDOList = propertyValueService.getPropertyValueListByPropertyId(propertyIds); + List propertyValueRespVOList = PropertyValueConvert.INSTANCE.convertList(propertyValueDOList); + //组装一对多 + propertyRespVOPageResult.getList().stream().forEach(x->{ + Long propertyId = x.getId(); + List valueDOList = propertyValueRespVOList.stream().filter(v -> v.getPropertyId().equals(propertyId)).collect(Collectors.toList()); + x.setPropertyValueList(valueDOList); + }); + return propertyRespVOPageResult; + } + + @Override + public ProductPropertyRespVO getPropertyResp(Long id) { + //查询规格 + ProductPropertyDO property = getProperty(id); + ProductPropertyRespVO propertyRespVO = ProductPropertyConvert.INSTANCE.convert(property); + //查询属性值 + List valueDOList = propertyValueService.getPropertyValueListByPropertyId(Arrays.asList(id)); + List propertyValueRespVOS = PropertyValueConvert.INSTANCE.convertList(valueDOList); + //组装 + propertyRespVO.setPropertyValueList(propertyValueRespVOS); + return propertyRespVO; + } + } diff --git a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/service/propertyvalue/PropertyValueService.java b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/service/propertyvalue/PropertyValueService.java index 0e04e4bd9..94fb44f67 100755 --- a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/service/propertyvalue/PropertyValueService.java +++ b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/service/propertyvalue/PropertyValueService.java @@ -67,4 +67,22 @@ public interface PropertyValueService { */ List getPropertyValueList(PropertyValueExportReqVO exportReqVO); + /** + * 批量插入属性值 + * @param propertyValues + */ + void batchInsert(List propertyValues); + + /** + * 根据属性id查询 + * @param propertyIds + * @return + */ + List getPropertyValueListByPropertyId(List propertyIds); + + /** + * 根据属性id 删除 + * @param propertyId + */ + void deletePropertyValueByPropertyId(Long propertyId); } diff --git a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/service/propertyvalue/PropertyValueServiceImpl.java b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/service/propertyvalue/PropertyValueServiceImpl.java index d647d3e2e..15ea4e72e 100755 --- a/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/service/propertyvalue/PropertyValueServiceImpl.java +++ b/yudao-module-mall/yudao-module-product-biz/src/main/java/cn/iocoder/yudao/module/product/service/propertyvalue/PropertyValueServiceImpl.java @@ -1,10 +1,7 @@ package cn.iocoder.yudao.module.product.service.propertyvalue; import cn.iocoder.yudao.framework.common.pojo.PageResult; -import cn.iocoder.yudao.module.product.controller.admin.propertyvalue.vo.PropertyValueCreateReqVO; -import cn.iocoder.yudao.module.product.controller.admin.propertyvalue.vo.PropertyValueExportReqVO; -import cn.iocoder.yudao.module.product.controller.admin.propertyvalue.vo.PropertyValuePageReqVO; -import cn.iocoder.yudao.module.product.controller.admin.propertyvalue.vo.PropertyValueUpdateReqVO; +import cn.iocoder.yudao.module.product.controller.admin.propertyvalue.vo.*; import cn.iocoder.yudao.module.product.convert.propertyvalue.PropertyValueConvert; import cn.iocoder.yudao.module.product.dal.dataobject.propertyvalue.PropertyValueDO; import cn.iocoder.yudao.module.product.dal.mysql.propertyvalue.PropertyValueMapper; @@ -84,4 +81,19 @@ public class PropertyValueServiceImpl implements PropertyValueService { return propertyValueMapper.selectList(exportReqVO); } + @Override + public void batchInsert(List propertyValues) { + propertyValueMapper.insertBatch(propertyValues); + } + + @Override + public List getPropertyValueListByPropertyId(List propertyIds) { + return propertyValueMapper.getPropertyValueListByPropertyId(propertyIds); + } + + @Override + public void deletePropertyValueByPropertyId(Long propertyId) { + propertyValueMapper.deletePropertyValueByPropertyId(propertyId); + } + } diff --git a/yudao-ui-admin/src/views/mall/product/property/index.vue b/yudao-ui-admin/src/views/mall/product/property/index.vue index 46881fe88..6fd222341 100644 --- a/yudao-ui-admin/src/views/mall/product/property/index.vue +++ b/yudao-ui-admin/src/views/mall/product/property/index.vue @@ -24,16 +24,17 @@ 新增 - - 导出 - + + +