SpuInfoController
/**
* 列表
*/
@RequestMapping("/list")
// @RequiresPermissions("product:spuinfo:list")
public R list(@RequestParam Map params){
PageUtils page = spuInfoService.queryPageCondition(params);
return R.ok().put("page", page);
}
SpuInfoService
PageUtils queryPageCondition(Map params);
SpuInfoServiceImpl
@Override
public PageUtils queryPageCondition(Map params) {
QueryWrapper wrapper = new QueryWrapper<>();
// 关键字检索
Object key = params.get("key");
// 三级分类id
Object catalogId = params.get("catalogId");
// 品牌id
Object brandId = params.get("brandId");
// 状态 0-新建 1-上架 2-下架
Object status = params.get("status");
if (!StringUtils.isEmpty(key)){
wrapper.and((w) -> {
w.eq("id",key).or().like("spu_name",key);
});
}
if (!StringUtils.isEmpty(catalogId)){
wrapper.eq("catalog_id",catalogId);
}
if (!StringUtils.isEmpty(brandId)){
wrapper.eq("brand_id",brandId);
}
if (!StringUtils.isEmpty(status)){
wrapper.eq("publish_status",status);
}
IPage page = this.page(
new Query().getPage(params),
wrapper
);
return new PageUtils(page);
}
查询时创建时间不是年月日时分秒类型。可以在全局配置文件中配置:
jackson:
date-format: yyyy-MM-dd HH:mm:ss
后端代码修改:
SpuInfoServiceImpl
if (!StringUtils.isEmpty(catalogId) && !"0".equals(catalogId)){
wrapper.eq("catalog_id",catalogId);
}
if (!StringUtils.isEmpty(brandId) && !"0".equals(brandId)){
wrapper.eq("brand_id",brandId);
}
前端调用时出现第一次进入页面。搜索时输入框条件未置空,且为0.是因为业务规则,传0就查全部。后端需要改代码。
/**
* 列表
*/
@RequestMapping("/list")
// @RequiresPermissions("product:skuinfo:list")
public R list(@RequestParam Map params){
PageUtils page = skuInfoService.queryPageByCondition(params);
return R.ok().put("page", page);
}
SkuInfoService
PageUtils queryPageByCondition(Map params);
SkuInfoServiceImpl
@Override
public PageUtils queryPageByCondition(Map params) {
QueryWrapper wrapper = new QueryWrapper<>();
Object key = params.get("key");
Object catelogId = params.get("catelogId");
Object brandId = params.get("brandId");
Object min = params.get("min");
Object max = params.get("max");
if (!StringUtils.isEmpty(key)){
wrapper.and((w) -> {
w.eq("sku_id",key).or().like("sku_name",key);
});
}
if (!StringUtils.isEmpty(catelogId) && !"0".equals(catelogId)){
wrapper.eq("catalog_id",catelogId);
}
if (!StringUtils.isEmpty(brandId) && !"0".equals(brandId)){
wrapper.eq("brand_id",brandId);
}
if (!StringUtils.isEmpty(min)){
wrapper.ge("price",min);
}
if (!StringUtils.isEmpty(max)){
BigDecimal bigDecimal = new BigDecimal((String) max);
if (bigDecimal.compareTo(new BigDecimal("0")) > 0){
// 当价格区间的最大值大于0才去拼接
wrapper.le("price",max);
}
}
IPage page = this.page(
new Query().getPage(params),
wrapper
);
return new PageUtils(page);
}
解决方案如下:
spu管理规格404问题修复方案
注意和parent_id绑定,建议以菜单按钮新增方式
AttrController
/**
* 获取spu规格
*/
@RequestMapping("/base/listforspu/{spuId}")
// @RequiresPermissions("product:attr:list")
public R getListForspu(@PathVariable Long spuId){
List list = attrService.getListForspu(spuId);
return R.ok().put("data", list);
}
AttrService
List getListForspu(Long spuId);
AttrServiceImpl
@Override
public List getListForspu(Long spuId) {
return productAttrValueService.getBaseMapper().selectList(new QueryWrapper().eq("spu_id",spuId));
}
解决方案如下:
前端+后端此接口修改方式
根据此文档修改以后
重新新增一个商品
可以正常回显了。但是多次点击又不能正常回显。
AttrController
/**
* 获取spu规格
*/
@PostMapping("/update/{spuId}")
// @RequiresPermissions("product:attr:list")
public R updateProductSpu(@PathVariable Long spuId,@RequestBody List entityList){
attrService.updateProductSpu(spuId,entityList);
return R.ok();
}
AttrService
void updateProductSpu(Long spuId, List entityList);
AttrServiceImpl
@Transactional
@Override
public void updateProductSpu(Long spuId, List entityList) {
// 删除后新增
// 1、根据spuId删除spu属性值表
productAttrValueService.getBaseMapper().delete(new QueryWrapper().eq("spu_id",spuId));
// 2、批量新增
entityList = entityList.stream().map(entity -> {
entity.setSpuId(spuId);
return entity;
}).collect(Collectors.toList());
productAttrValueService.saveBatch(entityList);
}
application.yml
application:
name: gulimall-ware
GulimallWareApplication
@SpringBootApplication
@EnableDiscoveryClient
@EnableTransactionManagement
@MapperScan("com.ljs.gulimall.ware.dao")
public class GulimallWareApplication {
public static void main(String[] args) {
SpringApplication.run(GulimallWareApplication.class, args);
}
}
启动ware服务。登录nacos
gulimall-gateway配置路由规则
application.yml
- id: ware_route
#负载均衡到member服务
uri: lb://gulimall-ware
predicates:
- Path=/api/ware/**
#网关重写
filters:
- RewritePath=/api/(?.*),/$\{segment}
仓库列表
WareInfoServiceImpl
@Override
public PageUtils queryPage(Map params) {
QueryWrapper wrapper = new QueryWrapper<>();
Object key = params.get("key");
if (!StringUtils.isEmpty(key)){
wrapper.eq("id", key).or().like("name",key).or().
like("address",key).or().like("areacode",key);
}
IPage page = this.page(
new Query().getPage(params),
wrapper
);
return new PageUtils(page);
}
查询商品库存
WareSkuServiceImpl
@Override
public PageUtils queryPage(Map params) {
QueryWrapper wrapper = new QueryWrapper<>();
Object skuId = params.get("skuId");
if (!StringUtils.isEmpty(skuId)){
wrapper.eq("sku_id",skuId);
}
Object wareId = params.get("wareId");
if (!StringUtils.isEmpty(wareId)){
wrapper.eq("ware_id",wareId);
}
IPage page = this.page(
new Query().getPage(params),
wrapper
);
return new PageUtils(page);
}
查询采购需求
PurchaseDetailServiceImpl
@Override
public PageUtils queryPage(Map params) {
QueryWrapper wrapper = new QueryWrapper<>();
Object key = params.get("key");
if (!StringUtils.isEmpty(key)){
wrapper.and((w) -> {
w.eq("id",key).or().eq("sku_id",key).or().eq("sku_num",key);
});
}
Object status = params.get("status");
if (!StringUtils.isEmpty(status)){
wrapper.eq("status",status);
}
Object wareId = params.get("wareId");
if (!StringUtils.isEmpty(wareId)){
wrapper.eq("ware_id",wareId);
}
IPage page = this.page(
new Query().getPage(params),
wrapper
);
return new PageUtils(page);
}
查询未领取的采购单
PurchaseController
/**
* 列表
*/
@RequestMapping("/unreceive/list")
// @RequiresPermissions("ware:purchase:list")
public R unreceiveList(@RequestParam Map params){
PageUtils page = purchaseService.queryUnReceivePage(params);
return R.ok().put("page", page);
}
PurchaseService
PageUtils queryUnReceivePage(Map params);
PurchaseServiceImpl
@Override
public PageUtils queryUnReceivePage(Map params) {
QueryWrapper wrapper = new QueryWrapper<>();
wrapper.and(item -> {item.eq("status",1).or().eq("status",0);});
IPage page = this.page(
new Query().getPage(params),
wrapper
);
return new PageUtils(page);
}
分配好以后再点击合并采购单
合并采购需求
PurchaseController
/**
* 合并采购需求
*/
@RequestMapping("/merge")
// @RequiresPermissions("ware:purchase:list")
public R merge(@RequestBody PurchaseMergeEntity mergeEntity){
purchaseService.merge(mergeEntity);
return R.ok();
}
PurchaseService
void merge(PurchaseMergeEntity mergeEntity);
PurchaseServiceImpl
@Transactional
@Override
public void merge(PurchaseMergeEntity mergeEntity) {
Long purchaseId = mergeEntity.getPurchaseId();
if (purchaseId == null){
// 新建合并单
PurchaseEntity purchaseEntity = new PurchaseEntity();
purchaseEntity.setStatus(PurchaseEnum.CREATED.getCode());
this.save(purchaseEntity);
purchaseId = purchaseEntity.getId();
}
// 修改合并项信息
List items = mergeEntity.getItems();
Long finalPurchaseId = purchaseId;
List collect = items.stream().map(
(id) -> {
PurchaseDetailEntity purchaseDetailEntity = new PurchaseDetailEntity();
purchaseDetailEntity.setId(id);
purchaseDetailEntity.setPurchaseId(finalPurchaseId);
purchaseDetailEntity.setStatus(PurchaseDetailEnum.ASSIGNED.getCode());
return purchaseDetailEntity;
}
).collect(Collectors.toList());
purchaseDetailService.updateBatchById(collect);
// 更新采购单更新时间
PurchaseEntity purchaseEntity = new PurchaseEntity();
purchaseEntity.setId(purchaseId);
purchaseEntity.setUpdateTime(new Date());
this.updateById(purchaseEntity);
}
领取采购单
PurchaseController
/**
* 领取采购单
*/
@PostMapping("/received")
// @RequiresPermissions("ware:purchase:list")
public R merge(@RequestBody List ids){
purchaseService.received(ids);
return R.ok();
}
PurchaseServiceImpl
@Transactional
@Override
public void received(List ids) {
// 1、确认当前采购单是否新建或已分配状态
List collect = ids.stream().map(this::getById).
filter(item -> {
if (PurchaseEnum.CREATED.getCode().equals(item.getStatus()) || PurchaseEnum.ASSIGNED.getCode().equals(item.getStatus())) {
return true;
}
return false;
}).map(item -> {
item.setUpdateTime(new Date());
item.setStatus(PurchaseEnum.RECEIVED.getCode());
return item;
}).collect(Collectors.toList());
// 2、改变采购单状态
if (collect.size() == 0){
return;
}
this.updateBatchById(collect);
// 3、改变采购单详情状态
collect.forEach(item -> {
List list = purchaseDetailService.list(new QueryWrapper().eq("purchase_id", item.getId()));
List collect1 = list.stream().map(updateItem -> {
PurchaseDetailEntity detailEntity = new PurchaseDetailEntity();
detailEntity.setId(updateItem.getId());
detailEntity.setStatus(PurchaseDetailEnum.RECEIVED.getCode());
return detailEntity;
}).collect(Collectors.toList());
if (collect1.size() > 0){
purchaseDetailService.updateBatchById(collect1);
}
});
}
@Transactional
@Override
public void merge(PurchaseMergeEntity mergeEntity) {
Long purchaseId = mergeEntity.getPurchaseId();
if (purchaseId == null){
// 新建合并单
PurchaseEntity purchaseEntity = new PurchaseEntity();
purchaseEntity.setStatus(PurchaseEnum.CREATED.getCode());
this.save(purchaseEntity);
purchaseId = purchaseEntity.getId();
}
// 合并采购需求时判断合并单新建和已分配状态。其他状态不给合并
PurchaseEntity entity = this.getById(purchaseId);
if (entity != null && (!PurchaseEnum.CREATED.getCode().equals(entity.getStatus()) && !PurchaseEnum.ASSIGNED.getCode().equals(entity.getStatus()))){
throw new RuntimeException("有合并单:" + purchaseId + "不是新建或已分配状态,不允许合并");
}
// 修改合并项信息
List items = mergeEntity.getItems();
Long finalPurchaseId = purchaseId;
List collect = items.stream().map(
(id) -> {
PurchaseDetailEntity purchaseDetailEntity = new PurchaseDetailEntity();
purchaseDetailEntity.setId(id);
purchaseDetailEntity.setPurchaseId(finalPurchaseId);
purchaseDetailEntity.setStatus(PurchaseDetailEnum.ASSIGNED.getCode());
return purchaseDetailEntity;
}
).collect(Collectors.toList());
purchaseDetailService.updateBatchById(collect);
// 更新采购单更新时间
PurchaseEntity purchaseEntity = new PurchaseEntity();
purchaseEntity.setId(purchaseId);
purchaseEntity.setUpdateTime(new Date());
this.updateById(purchaseEntity);
}
完成采购
PurchaseController
/**
* 完成采购
*/
@PostMapping("/done")
// @RequiresPermissions("ware:purchase:list")
public R done(@RequestBody PurchaseDoneVO purchaseDoneVO){
purchaseService.done(purchaseDoneVO);
return R.ok();
}
PurchaseService
void done(PurchaseDoneVO purchaseDoneVO);
PurchaseServiceImpl
@Transactional
@Override
public void done(PurchaseDoneVO purchaseDoneVO) {
// 1、改变采购项状态
List items = purchaseDoneVO.getItems();
items.forEach(item -> {
PurchaseDetailEntity entity = new PurchaseDetailEntity();
BeanUtils.copyProperties(item,entity);
purchaseDetailService.updateById(entity);
});
// 2、根据采购项状态改变采购单状态
boolean flag = true;
for (PurchaseItemDoneVO item : items) {
PurchaseDetailEntity entity = new PurchaseDetailEntity();
entity.setId(item.getItemId());
if (!PurchaseDetailEnum.FINISHED.getCode().equals(item.getStatus())) {
flag = false;
entity.setStatus(PurchaseDetailEnum.HASERROR.getCode());
purchaseDetailService.updateById(entity);
} else {
entity.setStatus(PurchaseDetailEnum.FINISHED.getCode());
purchaseDetailService.updateById(entity);
// 3、新增或修改库存
Long itemId = item.getItemId();
PurchaseDetailEntity detailEntity = purchaseDetailService.getBaseMapper().selectById(itemId);
if (detailEntity != null){
Long skuId = detailEntity.getSkuId();
Integer skuNum = detailEntity.getSkuNum();
Long wareId = detailEntity.getWareId();
QueryWrapper wrapper = new QueryWrapper().eq("sku_id", skuId).eq("ware_id", wareId);
List list = wareSkuService.list(wrapper);
WareSkuEntity wareSkuEntity = new WareSkuEntity();
BeanUtils.copyProperties(detailEntity,wareSkuEntity);
wareSkuEntity.setStock(skuNum);
if (list == null || list.size() == 0){
// 新增
wareSkuEntity.setStockLocked(0);
// 调用远程接口获取skuName。并且保证事务不回滚
try{
R info = productFeignService.info(skuId);
if (info.getCode() == 0){
Map data = (Map) info.get("skuInfo");
wareSkuEntity.setSkuName((String)data.get("skuName"));
}
}catch (Exception e){
}
wareSkuEntity.setStock(skuNum);
wareSkuService.addStock(wareSkuEntity);
} else {
// 修改
wareSkuService.updateStock(wareSkuEntity);
}
}
}
}
Long id = purchaseDoneVO.getId();
PurchaseEntity entity = new PurchaseEntity();
entity.setId(id);
entity.setStatus(flag ? PurchaseEnum.FINISHED.getCode() : PurchaseEnum.HASERROR.getCode());
this.updateById(entity);
}
ProductFeignService
package com.ljs.gulimall.ware.feign;
import com.ljs.gulimall.common.utils.R;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
@FeignClient("gulimall-product")
public interface ProductFeignService {
/**
* 根据skuId获取sku信息
*
* @param skuId skuId
* @return R
*/
@RequestMapping("/product/skuinfo/info/{skuId}")
R info(@PathVariable("skuId") Long skuId);
}
GulimallWareApplication
@EnableFeignClients
WareSkuService
void addStock(WareSkuEntity wareSkuEntity);
void updateStock(WareSkuEntity wareSkuEntity);
WareSkuServiceImpl
@Override
public void addStock(WareSkuEntity wareSkuEntity) {
wareSkuDao.addStock(wareSkuEntity);
}
@Override
public void updateStock(WareSkuEntity wareSkuEntity) {
wareSkuDao.updateStock(wareSkuEntity);
}
WareSkuDao
void addStock(WareSkuEntity wareSkuEntity);
void updateStock(WareSkuEntity wareSkuEntity);
WareSkuDao.xml
insert into
wms_ware_sku
(`sku_id`,`ware_id`,`stock`,`sku_name`,`stock_locked`)
values
(#{skuId},#{wareId},#{stock},#{skuName},#{stockLocked})
update
wms_ware_sku
set
stock = stock + #{stock}
where sku_id = #{skuId}
and ware_id = #{wareId}