商品模块展现
1.编辑POJO对象
/**
* @author 刘昱江
* 时间 2021/4/7
*/
@TableName("item")
@Data
@Accessors(chain = true)
public class Item extends BasePojo{
@TableId(type = IdType.AUTO)
private Integer id; //商品Id号
private String title; //商品标题信息
private String sellPoint; //卖点信息
private Integer price; //商品价格 扩大100倍 缩小100倍值不变
private Integer num; //商品数量
private String images; //商品图片
private Integer itemCatId; //商品分类ID号
private Boolean status; //状态信息 0 下架 1 上架
}
1.2编辑ItemController
/**
* 需求: 查询商品列表 分页查询
* URL: /item/getItemList?query=&pageNum=1&pageSize=10
* 参数: pageResult
* 返回值: SysResult(pageResult)
*/
@GetMapping("/getItemList")
public SysResult getItemList(PageResult pageResult){//3
//参照user模块完成商品分页查询.
pageResult = itemService.getItemList(pageResult);//+2
return SysResult.success(pageResult);
}
1.3 编辑ItemService
/**
* 需求: 实现商品分页查询
* @param pageResult
* @return
*/
@Override
public PageResult getItemList(PageResult pageResult) {
IPage page = new Page(pageResult.getPageNum(),pageResult.getPageSize());
QueryWrapper<Item> queryWrapper = new QueryWrapper<>();
//判断条件: 用户传递query 则添加where条件
String query = pageResult.getQuery();
boolean flag = StringUtils.hasLength(query);
queryWrapper.like(flag,"title",query);
//page接口原来只有2个,经过分页查询之后,有四个结果
page = itemMapper.selectPage(page,queryWrapper);
long total = page.getTotal();
List<Item> rows = page.getRecords();
return pageResult.setTotal(total).setRows(rows);
}
1.4 页面效果展现
?2.商品新增
2.1封装ItemVO对象:为了提升效率,减低数据库中的表查询负荷,在两张表需要联合的时候尽量不要加主外键约束
说明:
Item中存储的是商品的基本信息,通常用于检索,或者数据展现. itemDesc一般存储的都是商品的详情信息. 为了用户的检索效率更好,所以一般先查询item数据,(itemDesc一般采用大字段的形式,存储html代码的片段).
要求: 一个商品对应一个详情信息, 所以 item和itemDesc一对一 一个商品对应一个详情 一个详情对应一个商品 隐藏属性: item.id = itemDesc.id 2.2封装ItemVO对象:为了降低商品提交代码的耦合性,将大字段信息详情,采用ItemDesc对象进行封装
/**
* 此表用于将两个表id联合在一起
*
*/
@Data
@Accessors(chain = true)
@NoArgsConstructor
@AllArgsConstructor
public class ItemVO { //该对象封装商品所有的参数信息
private Item item;
private ItemDesc itemDesc;
private ItemParam itemParam;
}
2.2 编辑ItemDesc
package com.jt.pojo;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
import lombok.experimental.Accessors;
@TableName("item_desc")
@Data
@Accessors(chain = true)
public class ItemDesc extends BasePojo {
/**
* item要与itemDesc一对一,ID要一样
* 目的简化外键约束
*/
@TableId
private Integer id;
private String itemDesc;
}
2.3在ItemController中创建
/**
* 业务分析: 实现商品新增操作
* URL地址: http://localhost:8091/item/saveItem
* 参数: ItemVO的JSON串 {item,itemDesc}
* 返回值: SysResult对象
*/
@PostMapping("/saveItem")
public SysResult saveItem(@RequestBody ItemVO itemVO){
itemService.saveItem(itemVO);
return SysResult.success();
}
2.4在ItemServiceImpl注入ItemDescMapper
?
/**
* 实现商品入库:
* 1.入库前没有主键,需要入库后才能有主键
* 2.两张表要实现外键约束
* */
@Override
public void saveItem(ItemVO itemVO) {
Item item = itemVO.getItem();
item.setStatus(true);
//问题: 入库之后才有ID,现阶段item.id=null
//mybatis实现业务功能,自动回显主键!!!
//MP自动的将主键的回显功能实现!!!
itemMapper.insert(item);
ItemDesc itemDesc = itemVO.getItemDesc();
//规则: itemId与ItemDescId是一样的.
itemDesc.setId(item.getId());
itemDescMapper.insert(itemDesc);
}
}
|