ApiFootprintMapper.xml 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  3. <mapper namespace="com.kmall.api.dao.ApiFootprintMapper">
  4. <!-- 可根据自己的需求,是否要使用 -->
  5. <resultMap type="com.kmall.api.entity.FootprintVo" id="footprintMap">
  6. <result property="id" column="id"/>
  7. <result property="user_id" column="user_id"/>
  8. <result property="goods_id" column="goods_id"/>
  9. <result property="add_time" column="add_time"/>
  10. <result property="name" column="name"/>
  11. <result property="list_pic_url" column="list_pic_url"/>
  12. <result property="goods_brief" column="goods_brief"/>
  13. <result property="retail_price" column="retail_price"/>
  14. <result property="referrer" column="referrer"/>
  15. <result property="nickname" column="nickname"/>
  16. <result property="avatar" column="avatar"/>
  17. </resultMap>
  18. <select id="queryObject" resultMap="footprintMap">
  19. select f.id,f.user_id,f.goods_id,f.add_time add_time,f.referrer from mall_footprint f where id = #{value}
  20. </select>
  21. <select id="queryList" resultMap="footprintMap">
  22. select f.id,f.user_id,f.goods_id,f.add_time add_time,f.referrer,
  23. g.name as name, g.list_pic_url as list_pic_url, g.goods_brief as goods_brief, psr.retail_price as
  24. retail_price
  25. from mall_footprint f
  26. <if test="maxFoot == true">
  27. left join mall_footprint max on f.goods_id = max.goods_id and f.user_id = max.user_id
  28. and max.add_time > f.add_time
  29. </if>
  30. left join mall_goods g on f.goods_id = g.id
  31. LEFT JOIN mall_product_store_rela psr ON psr.goods_id = g.id
  32. <where>
  33. 1=1 and psr.stock_num >0
  34. <if test="user_id != null">
  35. and f.user_id = #{user_id}
  36. </if>
  37. <if test="maxFoot == true">
  38. and max.id is null
  39. </if>
  40. <if test="bizType == true">
  41. and g.goods_biz_type in ('00','11')
  42. </if>
  43. <if test="store_id != null and store_id != ''">
  44. and psr.store_id = #{store_id}
  45. </if>
  46. </where>
  47. <choose>
  48. <when test="sidx != null and sidx.trim() != ''">
  49. order by ${sidx} ${order}
  50. </when>
  51. <otherwise>
  52. order by f.id desc
  53. </otherwise>
  54. </choose>
  55. <if test="offset != null and limit != null">
  56. limit #{offset}, #{limit}
  57. </if>
  58. </select>
  59. <select id="queryTotal" resultType="int">
  60. select count(*) from mall_footprint f
  61. <where>
  62. <if test="user_id != null">
  63. and f.user_id = #{user_id}
  64. </if>
  65. <if test="goods_id != null">
  66. and f.goods_id = #{goods_id}
  67. </if>
  68. <if test="referrer != null">
  69. and f.referrer = #{referrer}
  70. </if>
  71. </where>
  72. </select>
  73. <insert id="save" parameterType="com.kmall.api.entity.FootprintVo" useGeneratedKeys="true" keyProperty="id">
  74. insert into mall_footprint
  75. (
  76. `user_id`,
  77. `goods_id`,
  78. `add_time`,
  79. `referrer`
  80. )
  81. values
  82. (
  83. #{user_id},
  84. #{goods_id},
  85. #{add_time},
  86. #{referrer}
  87. )
  88. </insert>
  89. <update id="update" parameterType="com.kmall.api.entity.FootprintVo">
  90. update mall_footprint
  91. <set>
  92. <if test="user_id != null">`user_id` = #{user_id},</if>
  93. <if test="goods_id != null">`goods_id` = #{goods_id},</if>
  94. <if test="add_time != null">`add_time` = #{add_time}</if>
  95. <if test="referrer != null">`referrer` = #{referrer}</if>
  96. </set>
  97. where id = #{id}
  98. </update>
  99. <delete id="delete">
  100. delete from mall_footprint where id = #{value}
  101. </delete>
  102. <delete id="deleteByParam">
  103. delete from mall_footprint
  104. where 1 = 1
  105. <if test="userId != null">and `user_id` = #{userId},</if>
  106. <if test="goodsId != null">and `goods_id` = #{goodsId},</if>
  107. </delete>
  108. <delete id="deleteBatch">
  109. delete from mall_footprint where id in
  110. <foreach item="id" collection="array" open="(" separator="," close=")">
  111. #{id}
  112. </foreach>
  113. </delete>
  114. <select id="shareList" resultMap="footprintMap">
  115. select f.id,f.user_id,f.goods_id,f.add_time add_time,f.referrer,
  116. g.name as name, g.list_pic_url as list_pic_url, g.goods_brief as goods_brief,
  117. psr.retail_price as retail_price,
  118. u.nickname as nickname,u.avatar as avatar
  119. from mall_footprint f
  120. left join mall_goods g on f.goods_id = g.id
  121. left join mall_user u on u.id = f.user_id
  122. LEFT JOIN mall_product_store_rela psr ON psr.goods_id = g.id
  123. <where>
  124. u.id is not null
  125. <if test="user_id != null">
  126. and f.user_id = #{user_id}
  127. </if>
  128. <if test="referrer != null">
  129. and f.referrer = #{referrer}
  130. </if>
  131. <if test="store_id != null and store_id != ''">
  132. and psr.store_id = #{store_id}
  133. </if>
  134. </where>
  135. <choose>
  136. <when test="sidx != null and sidx.trim() != ''">
  137. order by ${sidx} ${order}
  138. </when>
  139. <otherwise>
  140. order by f.id desc
  141. </otherwise>
  142. </choose>
  143. <if test="offset != null and limit != null">
  144. limit #{offset}, #{limit}
  145. </if>
  146. </select>
  147. </mapper>