SELECT
pro.*,
sm.supplier_name as supplier_name,
pl.purchase_contract_number as purchase_contract_number
FROM purchase_return_orders pro
LEFT JOIN supplier_manage sm ON pro.supplier_id = sm.id
LEFT JOIN purchase_ledger pl ON pl.id = pro.purchase_ledger_id
AND pro.no LIKE CONCAT('%',#{params.no},'%')
AND pro.dept_id = #{params.deptId}
AND pro.dept_id IN
#{deptId}
AND pro.create_user = #{params.createUser}
ORDER BY pro.create_time DESC
where pro.id = #{id}
select pro.id,
pro.no returnNo,
sm.supplier_name,
pro.prepared_at,
pro.total_amount,
CASE pro.return_type WHEN 0 THEN '退货退款' WHEN 1 THEN '拒收' END AS returnType,
pl.purchase_contract_number
from purchase_return_orders pro
left join supplier_manage sm on pro.supplier_id = sm.id
left join purchase_ledger pl on pro.purchase_ledger_id = pl.id
where 1=1
and pro.no like concat('%',#{req.returnNo},'%')
and sm.supplier_name like concat('%',#{req.supplierName},'%')
AND DATE_FORMAT(pro.prepared_at, '%Y-%m-%d') BETWEEN #{req.startDate} AND #{req.endDate}
order by pro.id DESC
SELECT
sir.id,
slp.product_category,
slp.specification_model,
slp.unit,
sir.inbound_batches,
sir.stock_in_num,
sir.batch_no,
slp.tax_inclusive_unit_price,
GREATEST(sir.stock_in_num - COALESCE(rs.total_return_num, 0), 0) AS un_quantity,
COALESCE(rs.total_return_num, 0) AS total_return_num
FROM stock_in_record sir
LEFT JOIN quality_inspect qi ON sir.record_type = 10 AND sir.record_id = qi.id
LEFT JOIN purchase_ledger pl
ON pl.id = IF(sir.record_type = 7, sir.record_id, qi.purchase_ledger_id)
LEFT JOIN sales_ledger_product slp ON pl.id = slp.product_id
LEFT JOIN (
SELECT
stock_in_record_id,
SUM(return_quantity) AS total_return_num
FROM purchase_return_order_products prop
left join purchase_return_orders pro on pro.id = prop.purchase_return_order_id
WHERE 1=1
GROUP BY stock_in_record_id
) rs ON rs.stock_in_record_id = sir.id
WHERE sir.approval_status = 1 AND slp.type = 2
AND sir.record_type IN ('7','10')
and pl.id = #{purchaseLedgerId}