GoodsSkuMapper.xml 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278
  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.dk.mdm.mapper.mst.GoodsSkuMapper">
  4. <!-- 通用设置 -->
  5. <!-- 通用查询列 -->
  6. <sql id="Base_Column_List">
  7. sku_id, sku_code, sku_name, sku_model, brand_id, category_id, unit_id, sub_unit_id, conversion_factor
  8. , series_id, sku_spec, price_purchase, price_standard, price_wholesale, price_limited, price_other,sku_images
  9. , remarks, flg_valid, cp_id, op_create_time, op_create_user_id, op_update_time, op_update_user_id
  10. , op_app_code, op_timestamp, op_db_user
  11. </sql>
  12. <!-- 通用查询映射结果 -->
  13. <resultMap id="BaseResultMap" type="com.dk.mdm.model.pojo.mst.GoodsSku">
  14. <id column="sku_id" property="skuId"/>
  15. <result column="sku_code" property="skuCode"/>
  16. <result column="sku_name" property="skuName"/>
  17. <result column="sku_model" property="skuModel"/>
  18. <result column="brand_id" property="brandId" typeHandler="UuidTypeHandler"/>
  19. <result column="category_id" property="categoryId" typeHandler="UuidTypeHandler"/>
  20. <result column="unit_id" property="unitId" typeHandler="UuidTypeHandler"/>
  21. <result column="sub_unit_id" property="subUnitId" typeHandler="UuidTypeHandler"/>
  22. <result column="conversion_factor" property="conversionFactor"/>
  23. <result column="series_id" property="seriesId" typeHandler="UuidTypeHandler"/>
  24. <result column="sku_spec" property="skuSpec"/>
  25. <result column="price_purchase" property="pricePurchase"/>
  26. <result column="price_standard" property="priceStandard"/>
  27. <result column="price_wholesale" property="priceWholesale"/>
  28. <result column="price_limited" property="priceLimited"/>
  29. <result column="price_other" property="priceOther"/>
  30. <result column="sku_images" property="skuImages" typeHandler="JsonTypeHandler"/>
  31. <result column="remarks" property="remarks"/>
  32. <result column="flg_valid" property="flgValid"/>
  33. <result column="flg_sub_unit" property="flgSubUnit"/>
  34. <result column="flg_opening_inv" property="flgOpeningInv"/>
  35. <result column="flg_price" property="flgPrice"/>
  36. <result column="cp_id" property="cpId"/>
  37. <result column="op_create_time" property="opCreateTime" typeHandler="TimestampTypeHandler"/>
  38. <result column="op_create_user_id" property="opCreateUserId" typeHandler="UuidTypeHandler"/>
  39. <result column="op_update_time" property="opUpdateTime" typeHandler="TimestampTypeHandler"/>
  40. <result column="op_update_user_id" property="opUpdateUserId" typeHandler="UuidTypeHandler"/>
  41. <result column="op_app_code" property="opAppCode"/>
  42. <result column="op_timestamp" property="opTimestamp" typeHandler="TimestampTypeHandler"/>
  43. <result column="op_db_user" property="opDbUser"/>
  44. </resultMap>
  45. <sql id="Base_Column_List_JOIN">
  46. tmgs.price_other,tmgs.sku_id, tmgs.sku_code, tmgs.sku_name, tmgs.sku_model, tmgs.brand_id, tmgs.category_id, tmgs.unit_id, tmgs.sub_unit_id,
  47. tmgs.conversion_factor, tmgs.series_id, tmgs.sku_spec, tmgs.price_purchase, tmgs.price_standard,
  48. tmgs.pack_box, tmgs.price_wholesale, tmgs.price_limited, tmgs.price_other,tmgs.sku_images, tmgs.remarks, tmgs.flg_valid, tmgs.flg_sub_unit, tmgs.flg_opening_inv, tmgs.flg_price, tmgs.cp_id
  49. </sql>
  50. <resultMap id="BaseResultMapResponse" type="com.dk.mdm.model.response.mst.GoodsSkuResponse">
  51. <id column="sku_id" property="skuId"/>
  52. <result column="sku_code" property="skuCode"/>
  53. <result column="sku_name" property="skuName"/>
  54. <result column="sku_model" property="skuModel"/>
  55. <result column="brand_id" property="brandId" typeHandler="UuidTypeHandler"/>
  56. <result column="category_id" property="categoryId" typeHandler="UuidTypeHandler"/>
  57. <result column="unit_id" property="unitId" typeHandler="UuidTypeHandler"/>
  58. <result column="sub_unit_id" property="subUnitId" typeHandler="UuidTypeHandler"/>
  59. <result column="conversion_factor" property="conversionFactor"/>
  60. <result column="series_id" property="seriesId" typeHandler="UuidTypeHandler"/>
  61. <result column="sku_spec" property="skuSpec"/>
  62. <result column="price_purchase" property="pricePurchase"/>
  63. <result column="price_standard" property="priceStandard"/>
  64. <result column="price_wholesale" property="priceWholesale"/>
  65. <result column="price_other" property="priceOther"/>
  66. <result column="price_limited" property="priceLimited"/>
  67. <result column="price_other" property="priceOther"/>
  68. <result column="pack_box" property="packBox"/>
  69. <result column="sku_images" property="skuImages" typeHandler="JsonTypeHandler"/>
  70. <result column="remarks" property="remarks"/>
  71. <result column="flg_valid" property="flgValid"/>
  72. <result column="cp_id" property="cpId"/>
  73. <result column="inventoryCount" property="inventoryCount"/>
  74. </resultMap>
  75. <!-- 通用条件列 -->
  76. <sql id="Condition">
  77. <where>
  78. <if test="skuCode != null and skuCode != ''">
  79. AND tmgs.sku_code = #{skuCode}
  80. </if>
  81. <if test="skuName != null and skuName != ''">
  82. AND tmgs.sku_name = #{skuName}
  83. </if>
  84. <if test="skuModel != null and skuModel != ''">
  85. AND tmgs.sku_model = #{skuModel}
  86. </if>
  87. <if test="brandId != null and brandId != ''">
  88. AND tmgs.brand_id = #{brandId}::uuid
  89. </if>
  90. <if test="categoryId != null and categoryId != ''">
  91. AND tmgs.category_id = #{categoryId}::uuid
  92. </if>
  93. <if test="unitId != null and unitId != ''">
  94. AND tmgs.unit_id = #{unitId}::uuid
  95. </if>
  96. <if test="subUnitId != null and subUnitId != ''">
  97. AND tmgs.sub_unit_id = #{subUnitId}::uuid
  98. </if>
  99. <if test="conversionFactor != null">
  100. AND tmgs.conversion_factor = #{conversionFactor}
  101. </if>
  102. <if test="seriesId != null and seriesId != ''">
  103. AND tmgs.series_id = #{seriesId}::uuid
  104. </if>
  105. <if test="skuSpec != null and skuSpec != ''">
  106. AND tmgs.sku_spec = #{skuSpec}
  107. </if>
  108. <if test="pricePurchase != null">
  109. AND tmgs.price_purchase = #{pricePurchase}
  110. </if>
  111. <if test="priceStandard != null">
  112. AND tmgs.price_standard = #{priceStandard}
  113. </if>
  114. <if test="priceWholesale != null">
  115. AND tmgs.price_wholesale = #{priceWholesale}
  116. </if>
  117. <if test="priceLimited != null">
  118. AND tmgs.price_limited = #{priceLimited}
  119. </if>
  120. <if test="skuImages != null and skuImages != ''">
  121. AND tmgs.sku_images = #{skuImages}
  122. </if>
  123. <if test="remarks != null and remarks != ''">
  124. AND tmgs.remarks = #{remarks}
  125. </if>
  126. <if test="flgValid != null">
  127. AND tmgs.flg_valid = #{flgValid}
  128. </if>
  129. <if test="flgValidList != null and flgValidList.size>0">
  130. AND tmgs.flg_valid =any(#{flgValidList, typeHandler=BooleanListTypeHandler})
  131. </if>
  132. <if test="goodsBrandList != null and goodsBrandList.size>0">
  133. AND tmgs.brand_id =any(#{goodsBrandList, typeHandler=UuidListTypeHandler})
  134. </if>
  135. <if test="cpId != null">
  136. AND tmgs.cp_id = #{cpId}
  137. </if>
  138. <if test="brandIds != null">
  139. AND EXISTS (
  140. SELECT 1
  141. FROM unnest(string_to_array(#{brandIds}, ',')) AS brand_uuid
  142. WHERE brand_uuid::uuid = tmgs.brand_id
  143. )
  144. </if>
  145. <if test="searchText !=null">
  146. AND tmgs.sku_name LIKE concat('%', #{searchText}, '%')
  147. </if>
  148. </where>
  149. </sql>
  150. <sql id="idsForeach">
  151. <!-- 根据主键skuId批量操作 -->
  152. WHERE sku_id in
  153. <foreach collection="ids" index="index" item="item" separator="," open="(" close=")">
  154. #{item}
  155. </foreach>
  156. </sql>
  157. <!-- 查询表t_mst_goods_sku,(条件查询+分页)列表 -->
  158. <select id="selectByCond" resultMap="BaseResultMapResponse">
  159. SELECT
  160. <include refid="Base_Column_List_JOIN"/>
  161. ,tmgb.short_name AS "shortName"
  162. ,tmgb.brand_name AS "brandName",tmgsr.series_name AS "seriesName"
  163. ,COALESCE((SELECT sum(tpi.usable_qty) from dkic_b.t_psi_inventory tpi where tpi.sku_id = tmgs.sku_id and tpi.cp_id = #{cpId} ),0) AS "usableQty"
  164. FROM dkic_b.t_mst_goods_sku tmgs
  165. LEFT JOIN dkic_b.t_mst_goods_brand tmgb ON tmgb.brand_id = tmgs.brand_id
  166. LEFT JOIN dkic_b.t_mst_goods_series tmgsr ON tmgsr.series_id = tmgs.series_id
  167. <include refid="Condition"/>
  168. order by tmgs.op_create_time desc
  169. <if test="pageSize != null and currentPage != null and pageSize != 0 and currentPage != 0">
  170. limit #{end} offset #{start}
  171. </if>
  172. </select>
  173. <!-- 查询表t_mst_goods_sku,(条件查询)个数 -->
  174. <select id="countByCond" resultType="Long">
  175. SELECT
  176. count(1)
  177. FROM dkic_b.t_mst_goods_sku tmgs
  178. LEFT JOIN dkic_b.t_mst_goods_brand tmgb ON tmgb.brand_id = tmgs.brand_id
  179. LEFT JOIN dkic_b.t_mst_goods_series tmgsr ON tmgsr.series_id = tmgs.series_id
  180. <include refid="Condition"/>
  181. </select>
  182. <!-- 根据主键查询表t_mst_goods_sku的一行数据 -->
  183. <select id="selectById" resultMap="BaseResultMapResponse">
  184. SELECT
  185. <include refid="Base_Column_List_JOIN"/>
  186. ,tmgb.brand_name AS "brandName"
  187. ,tmgc.cat_name AS "catName"
  188. ,tmu.unit_name AS "unitName"
  189. ,subtmu.unit_name AS "subUnitName"
  190. ,tmgsr.series_name AS "seriesName"
  191. ,(SELECT count(1) FROM dkic_b.t_psi_inventory tsic WHERE tsic.sku_id = tmgs.sku_id ) AS inventoryCount
  192. FROM dkic_b.t_mst_goods_sku tmgs
  193. LEFT JOIN dkic_b.t_mst_goods_brand tmgb ON tmgb.brand_id = tmgs.brand_id
  194. LEFT JOIN dkic_b.t_mst_goods_category tmgc ON tmgc.cat_id = tmgs.category_id
  195. LEFT JOIN dkic_b.t_mst_unit tmu ON tmu.unit_id = tmgs.unit_id
  196. LEFT JOIN dkic_b.t_mst_unit subtmu ON subtmu.unit_id = tmgs.sub_unit_id
  197. LEFT JOIN dkic_b.t_mst_goods_series tmgsr ON tmgsr.series_id = tmgs.series_id
  198. WHERE tmgs.sku_id = #{id}::uuid
  199. </select>
  200. <!-- 根据主键锁定表t_mst_goods_sku的一行数据 -->
  201. <select id="selectByIdForUpdate" resultMap="BaseResultMap">
  202. SELECT
  203. <include refid="Base_Column_List"/>
  204. FROM dkic_b.t_mst_goods_sku
  205. WHERE sku_id = #{skuId}
  206. for update
  207. </select>
  208. <!-- 根据主键锁定表t_mst_goods_sku的多行数据 -->
  209. <select id="selectByIdsForUpdate" resultMap="BaseResultMap">
  210. SELECT
  211. <include refid="Base_Column_List"/>
  212. FROM dkic_b.t_mst_goods_sku
  213. <include refid="idsForeach"/>
  214. for update
  215. </select>
  216. <insert id="insertBatch">
  217. insert into dkic_b.t_mst_goods_sku
  218. (
  219. <trim suffixOverrides=",">
  220. sku_code,
  221. sku_name,
  222. sku_model,
  223. brand_id,
  224. category_id,
  225. unit_id,
  226. sub_unit_id,
  227. conversion_factor,
  228. series_id,
  229. sku_spec,
  230. price_purchase,
  231. price_standard,
  232. price_wholesale,
  233. price_limited,
  234. sku_images,
  235. remarks,
  236. cp_id,
  237. op_app_code,
  238. </trim>
  239. )
  240. values
  241. <foreach collection="list" index="index" item="item" separator=",">
  242. (
  243. <trim suffixOverrides=",">
  244. #{item.skuCode},
  245. #{item.skuName},
  246. #{item.skuModel},
  247. #{item.brandId}::uuid,
  248. #{item.categoryId}::uuid,
  249. #{item.unitId}::uuid,
  250. #{item.subUnitId}::uuid,
  251. #{item.conversionFactor},
  252. #{item.seriesId}::uuid,
  253. #{item.skuSpec},
  254. #{item.pricePurchase},
  255. #{item.priceStandard},
  256. #{item.priceWholesale},
  257. #{item.priceLimited},
  258. #{item.skuImages},
  259. #{item.remarks},
  260. #{item.cpId},
  261. #{item.opAppCode},
  262. </trim>
  263. )
  264. </foreach>
  265. </insert>
  266. </mapper>