public void update(Goods goods);
/**
*插入 SKU 列表数据
*@param goods
*/
private void saveItemList(Goods goods){
if("1".equals(goods.getGoods().getIsEnableSpec())){
for(TbItem item :goods.getItemList()){
.........中间代码略
}
}else{
TbItem item=new TbItem();
.........中间代码略itemMapper.insert(item);
}
}
public void add(Goods goods) {
goods.getGoods().setAuditStatus("0"); goodsMapper.insert(goods.getGoods()); //插入商品表
goods.getGoodsDesc().setGoodsId(goods.getGoods().getId());
goodsDescMapper.insert(goods.getGoodsDesc());//插入商品扩展数据
saveItemList(goods);//插入商品 SKU 列表数据
}
怎么样,是不是比原来更加清爽了呢?
接下来,我们修改 update 方法,实现修改
public void update(Goods goods){
goods.getGoods().setAuditStatus("0");//设置未申请状态:如果是经过修改的商品,需要重新设置状态
goodsMapper.updateByPrimaryKey(goods.getGoods());//保存商品表 goodsDescMapper.updateByPrimaryKey(goods.getGoodsDesc());//保存商品扩展表
//删除原有的 sku 列表数据
TbItemExample example=new TbItemExample(); com.pinyougou.pojo.TbItemExample.Criteria criteria = example.createCriteria(); criteria.andGoodsIdEqualTo(goods.getGoods().getId()); itemMapper.deleteByExample(example);
//添加新的 sku 列表数据
saveItemList(goods);//插入商品 SKU 列表数据
}
/**
*修改
*@param goods
*@return
*/ @RequestMapping("/update")
public Result update(@RequestBody Goods goods){
//校验是否是当前商家的 id
Goods goods2 = goodsService.findOne(goods.getGoods().getId());
//获取当前登录的商家 ID
String sellerId = SecurityContextHolder.getContext().getAuthentication().getName();
//如果传递过来的商家 ID 并不是当前登录的用户的 ID,则属于非法操作if(!goods2.getGoods().getSellerId().equals(sellerId)
|| !goods.getGoods().getSellerId().equals(sellerId) ){
return new Result(false, "操作非法");
}
try {
goodsService.update(goods);
return new Result(true, "修改成功");
} catch (Exception e) { e.printStackTrace();
return new Result(false, "修改失败");
}
}
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) | 黑马程序员IT技术论坛 X3.2 |