From f5c9d4c54da8d60d8b798f67679263a8aec1607f Mon Sep 17 00:00:00 2001
From: gongchunyi <deslre0381@gmail.com>
Date: 星期三, 15 四月 2026 11:16:48 +0800
Subject: [PATCH] feat: 库存区分产品大类
---
src/main/resources/mapper/basic/ProductModelMapper.xml | 44 ++++++++++++++++++++++++++++++++++++++------
1 files changed, 38 insertions(+), 6 deletions(-)
diff --git a/src/main/resources/mapper/basic/ProductModelMapper.xml b/src/main/resources/mapper/basic/ProductModelMapper.xml
index 317f5d9..cb80816 100644
--- a/src/main/resources/mapper/basic/ProductModelMapper.xml
+++ b/src/main/resources/mapper/basic/ProductModelMapper.xml
@@ -9,25 +9,57 @@
<result column="product_id" property="productId" />
<result column="model" property="model" />
<result column="unit" property="unit" />
+ <result column="thickness" property="thickness" />
<result column="speculative_trading_name" property="speculativeTradingName" />
<result column="tenant_id" property="tenantId" />
<result column="product_name" property="productName" />
<result column="product_id" property="productId" />
</resultMap>
+
<select id="listPageProductModel" resultType="com.ruoyi.basic.pojo.ProductModel">
- select pm.*,p.product_name
- from product_model pm
- left join product p on pm.product_id = p.id
+ WITH RECURSIVE product_tree AS (
+ SELECT
+ id,
+ product_name,
+ id AS top_id,
+ product_name AS top_name
+ FROM product
+ WHERE parent_id IS NULL OR parent_id = 0
+
+ UNION ALL
+
+ SELECT
+ p.id,
+ p.product_name,
+ t.top_id,
+ t.top_name
+ FROM product p
+ INNER JOIN product_tree t ON p.parent_id = t.id
+ )
+ SELECT
+ pm.*,
+ pt.product_name AS productName,
+ pt.top_name AS parentName
+ FROM product_model pm
+ LEFT JOIN product_tree pt ON pm.product_id = pt.id
<where>
+ <if test="c.parentId != null">
+ AND pt.top_id = #{c.parentId}
+ </if>
+
<if test="c.model != null and c.model != ''">
- and pm.model like concat('%',#{c.model},'%')
+ AND pm.model LIKE CONCAT('%', #{c.model}, '%')
</if>
<if test="c.productName != null and c.productName != ''">
- and p.product_name like concat('%',#{c.productName},'%')
+ AND pt.product_name LIKE CONCAT('%', #{c.productName}, '%')
+ </if>
+ <if test="c.parentName != null and c.parentName != ''">
+ AND pt.top_name LIKE CONCAT('%', #{c.parentName}, '%')
</if>
</where>
- order by pm.id
+ ORDER BY pm.id DESC
</select>
+
<select id="selectLatestRecord" resultType="com.ruoyi.basic.pojo.ProductModel">
SELECT * FROM product_model
ORDER BY create_time DESC, id DESC
--
Gitblit v1.9.3