张天森
2022-07-06 10f061e7c7723484d2c99554b5707f26176a3b0a
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
package com.panzhihua.service_community.dao;
 
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
 
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.panzhihua.common.model.dtos.shop.ComShopGoodsDTO;
import com.panzhihua.common.model.dtos.shop.PageComShopGoodsDTO;
import com.panzhihua.common.model.dtos.shop.PageComShopStoreDTO;
import com.panzhihua.common.model.vos.shop.ComShopGoodsVO;
import com.panzhihua.common.model.vos.shop.PageShopGoodsVO;
import com.panzhihua.service_community.model.dos.ComShopGoodsDO;
 
/**
 * @auther lyq
 * @create 2021-04-14 15:02:35
 * @describe 商品表mapper类
 */
@Mapper
public interface ComShopGoodsDAO extends BaseMapper<ComShopGoodsDO> {
 
    @Select("<script>"
        + "select c.id,c.type_id,css.name as storeName,c.name,c.store_id,c.goods_pic,c.images,c.status,c.sale,c.original_price,c.price,c.unit,c.order,c.stock,c.details,c.remark,c.goods_describe,c.delivery_type,c.delete_status,c.create_at,c.update_at from com_shop_goods c \n"
        + " left join com_shop_store css on c.store_id=css.id\n" + " <where>"
        + " and c.delete_status = 1 and css.delete_status = 1 "
        + "<if test='pageComShopGoodsDTO.storeName != null and pageComShopGoodsDTO.storeName.trim() != &quot;&quot;'>"
        + "and css.name like concat('%',#{pageComShopGoodsDTO.storeName},'%') \n" + " </if> "
        + "<if test='pageComShopGoodsDTO.name != null and pageComShopGoodsDTO.name.trim() != &quot;&quot;'>"
        + "and c.name like concat('%',#{pageComShopGoodsDTO.name},'%') \n" + " </if> "
        + "<if test='pageComShopGoodsDTO.storeId != null'>" + "and css.id=#{pageComShopGoodsDTO.storeId} \n" + " </if> "
        + "<if test='pageComShopGoodsDTO.status != null'>"
        + "and c.status like concat('%',#{pageComShopGoodsDTO.status},'%') \n" + " </if> " + " </where>"
        + " order by c.create_at desc" + "</script>")
    IPage<PageShopGoodsVO> pageShopGoods(Page page,
        @Param("pageComShopGoodsDTO") PageComShopGoodsDTO pageComShopGoodsDTO);
 
    /**
     * 根据店铺id查询商品列表
     *
     * @param page
     *            分页参数
     * @param pageComShopStoreDTO
     *            请求参数
     * @return 分页商品列表
     */
    @Select("<script> " + "select id,`name`,store_id,goods_pic,images,`status`,sale,original_price,price"
        + ",unit,`order`,stock,details,delivery_type from com_shop_goods"
        + " where store_id = #{pageComShopStoreDTO.storeId} and delete_status = 1 and status = 1"
        + " order by sale desc,create_at desc " + "</script> ")
    IPage<ComShopGoodsVO> pageShopGoodsByStoreId(Page page,
        @Param("pageComShopStoreDTO") PageComShopStoreDTO pageComShopStoreDTO);
 
    /**
     * 分页查询商品列表
     *
     * @param page
     *            分页参数
     * @param comShopGoodsDTO
     *            请求参数
     * @return 商品列表
     */
    @Select("<script> "
        + "select csg.id,csg.`name`,csg.store_id,csg.goods_pic,csg.images,csg.`status`,csg.sale,csg.original_price "
        + ",csg.price,csg.unit,csg.`order`,csg.stock,csg.details,csg.delivery_type, csg.create_at "
        + " from com_shop_goods as csg " + " left join com_shop_store as css on css.id = csg.store_id "
        + " where 1=1  and csg.delete_status = 1 and css.`status` = 1"
        + "<if test='comShopGoodsDTO.name != null and comShopGoodsDTO.name !=&quot;&quot;'>"
        + " AND csg.`name` like concat('%',#{comShopGoodsDTO.name},'%') " + " </if> "
        + "<if test='comShopGoodsDTO.status != null '>" + " AND csg.`status` = #{comShopGoodsDTO.status}" + " </if> "
        + "<if test='comShopGoodsDTO.storeId != null '>" + " AND csg.store_id = #{comShopGoodsDTO.storeId} " + " </if> "
        + "<if test='comShopGoodsDTO.status != null '>" + " AND csg.status = #{comShopGoodsDTO.status} " + " </if> "
        + "<if test='comShopGoodsDTO.deliveryType != null '>"
        + " AND csg.delivery_type = #{comShopGoodsDTO.deliveryType} " + " </if> "
        + " order by sale desc,create_at desc " + " </script>")
    IPage<ComShopGoodsVO> pageShopGoodByApps(Page page, @Param("comShopGoodsDTO") ComShopGoodsDTO comShopGoodsDTO);
}