《锋迷商城》系列项目
链接: 《一》 项目搭建
链接: 《二》数据库的创建
链接: 《三》业务流程设计
链接: 《四》业务流程实现:用户管理
链接: 《五》逆向工程
链接: 《六》用户认证
文章目录
十二、商品详情展示
12.1 实现流程分析
点击首页推荐的商品,轮播图商品广告,商品列表页面点击商品,就会进入到商品的详情页面
12.2 接口开发
12.2.1 商品基本信息接口
sql
-- 查询商品详情
-- 查询商品的基本信息
SELECT * FROM product where product_id=3
-- 查询商品图片
SELECT * FROM product_img where item_id=3
-- 查询商品规格 sku
SELECT * FROM product_sku where product_id=3
由于都是单表操作 使用tkMapper解决
业务层
/**
* 查询商品的基本ctId
* @return
*/
ResultVO getProductBasicInfo(String productId);
-----------------------------------------------
@Transactional(propagation = Propagation.SUPPORTS)
public ResultVO getProductBasicInfo(String productId) {
//商品基本信息
Example example = new Example(Product.class);
Example.Criteria criteria = example.createCriteria();
criteria.andEqualTo("productId", productId)
.andEqualTo("productStatus", 1);
List<Product> products = productMapper.selectByExample(example);
if (products.size() > 0) {
//商品图片
Example example1 = new Example(ProductImg.class);
Example.Criteria criteria1 = example1.createCriteria();
criteria1.andEqualTo("itemId", productId);
List<ProductImg> productImgs = productImgMapper.selectByExample(example1);
//商品规格
Example example2 = new Example(ProductSku.class);
Example.Criteria criteria2 = example2.createCriteria();
criteria2.andEqualTo("productId", productId);
List<ProductSku> productSkus = productSkuMapper.selectByExample(example2);
Map<String, Object> map = new HashMap<>();
map.put("product", products.get(0));
map.put("productImgs", productImgs);
map.put("productSkus", productSkus);
return new ResultVO(ResStatus.OK, "success", map);
} else {
return new ResultVO(ResStatus.NO, "商品不存在", null);
}
}
控制层
@RestController
@CrossOrigin
@RequestMapping("/product")
@Api(value = "提供商品所需的接口",tags = "商品管理")
public class ProductController {
@Autowired
private ProductService productService;
@ApiOperation("商品详情信息")
@GetMapping("/detail-info/{pid}")
public ResultVO getProductBasicInfo(@PathVariable("pid")