栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

jt项目实现-3

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

jt项目实现-3

商品模块展现 1.编辑POJO对象
@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
 
    @GetMapping("/getItemList")
    public SysResult getItemList(PageResult pageResult){//3

        //参照user模块完成商品分页查询.
        pageResult = itemService.getItemList(pageResult);//+2
        return SysResult.success(pageResult);
    }
1.3 编辑ItemService
 
    @Override
    public PageResult getItemList(PageResult pageResult) {

        IPage page = new Page(pageResult.getPageNum(),pageResult.getPageSize());
        QueryWrapper 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 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对象进行封装

@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 {
    
    @TableId
    private Integer id;
    private String itemDesc;
}

2.3在ItemController中创建

 
    @PostMapping("/saveItem")
    public SysResult saveItem(@RequestBody ItemVO itemVO){

        itemService.saveItem(itemVO);
        return SysResult.success();
    }

2.4在ItemServiceImpl注入ItemDescMapper

 

    @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);
    }
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/287678.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号