| | |
| | | where product_model_id = #{ew.productModelId} and qualitity >= #{ew.qualitity} |
| | | </update> |
| | | <select id="pagestockInventory" resultType="com.ruoyi.stock.dto.StockInventoryDto"> |
| | | WITH RECURSIVE get_root AS ( |
| | | SELECT |
| | | id, |
| | | parent_id, |
| | | id AS root_id |
| | | FROM product |
| | | WHERE parent_id IS NULL -- 根节点 |
| | | UNION ALL |
| | | SELECT |
| | | p.id, |
| | | p.parent_id, |
| | | gr.root_id |
| | | FROM product p |
| | | INNER JOIN get_root gr ON p.parent_id = gr.id |
| | | ) |
| | | SELECT |
| | | si.id, |
| | | si.qualitity, |
| | |
| | | pm.uid_no AS uidNo, |
| | | p.product_name, |
| | | si.batch_no, |
| | | si.customer |
| | | si.customer, |
| | | rp.product_name AS root_product_name, |
| | | si.production_date |
| | | FROM |
| | | stock_inventory si |
| | | LEFT JOIN product_model pm ON si.product_model_id = pm.id |
| | | LEFT JOIN product p ON pm.product_id = p.id |
| | | LEFT JOIN product p1 ON p.parent_id = p1.id |
| | | LEFT JOIN get_root gr ON gr.id = p.id |
| | | LEFT JOIN product rp ON rp.id = gr.root_id |
| | | <where> |
| | | <if test="ew.productName != null and ew.productName != ''"> |
| | | AND p.product_name LIKE CONCAT('%', #{ew.productName}, '%') |
| | |
| | | <if test="ew.productScope != null and ew.productScope != ''"> |
| | | <choose> |
| | | <when test="ew.productScope == '成品'"> |
| | | AND p1.product_name = #{ew.productScope} |
| | | AND rp.product_name = '成品' |
| | | </when> |
| | | <otherwise> |
| | | AND p1.product_name != '成品' |
| | | AND rp.product_name != '成品' |
| | | </otherwise> |
| | | </choose> |
| | | </if> |
| | |
| | | select si.qualitity, |
| | | pm.model, |
| | | pm.unit, |
| | | si.batchNo, |
| | | pm.uid_no, |
| | | si.production_date, |
| | | si.customer, |
| | | p.product_name, |
| | | coalesce(si.warn_num, 0) as warn_num, |
| | | coalesce(si.locked_quantity, 0) as locked_quantity, |
| | |
| | | p.parent_id AS parent_id, |
| | | p1.product_name AS parentName, |
| | | si.batch_no, |
| | | si.customer |
| | | si.customer, |
| | | si.production_date |
| | | FROM |
| | | stock_inventory si |
| | | LEFT JOIN product_model pm ON si.product_model_id = pm.id |