| | |
| | | GROUP BY sales_ledger_product_id |
| | | ) t3 ON t3.sales_ledger_product_id = T1.id |
| | | LEFT JOIN ( |
| | | SELECT |
| | | purchase_ledger_id, |
| | | product_model_id, |
| | | SELECT |
| | | purchase_ledger_id, |
| | | product_model_id, |
| | | SUM(IFNULL(quantity, 0)) AS approved_stock_in_num |
| | | FROM quality_inspect |
| | | WHERE inspect_state = 1 |
| | |
| | | JOIN product pr ON slp.product_id = pr.id |
| | | WHERE |
| | | slp.type = 2 |
| | | AND pr.parent_id = ( SELECT id FROM product WHERE product_name = '原材料' ) |
| | | AND pr.parent_id = ( SELECT id FROM product WHERE product_name = '原料' ) |
| | | GROUP BY |
| | | pr.id, |
| | | pr.product_name |
| | |
| | | |
| | | <select id="selectProductCountByTypeAndDate" resultType="int"> |
| | | SELECT IFNULL(COUNT(*), 0) |
| | | FROM sales_ledger_product |
| | | FROM sales_ledger_product slp |
| | | LEFT JOIN sales_ledger sl ON sl.id = slp.sales_ledger_id |
| | | LEFT JOIN purchase_ledger pl ON pl.id = slp.sales_ledger_id |
| | | WHERE type = #{type} |
| | | <if test="startDate != null"> |
| | | AND register_date >= #{startDate} |
| | | </if> |
| | | <if test="endDate != null"> |
| | | AND register_date <= #{endDate} |
| | | </if> |
| | | |
| | | <choose> |
| | | <when test="type == 1"> |
| | | <if test="startDate != null"> |
| | | AND sl.entry_date >= #{startDate} |
| | | </if> |
| | | <if test="endDate != null"> |
| | | AND sl.entry_date <= #{endDate} |
| | | </if> |
| | | </when> |
| | | |
| | | <when test="type == 2"> |
| | | <if test="startDate != null"> |
| | | AND pl.entry_date >= #{startDate} |
| | | </if> |
| | | <if test="endDate != null"> |
| | | AND pl.entry_date <= #{endDate} |
| | | </if> |
| | | </when> |
| | | </choose> |
| | | </select> |
| | | |
| | | <select id="selectRawMaterialExpense" resultType="java.math.BigDecimal"> |
| | | WITH RECURSIVE product_tree AS (SELECT id |
| | | FROM product |
| | | WHERE product_name = '原材料' |
| | | WHERE product_name = '原料' |
| | | |
| | | UNION ALL |
| | | |