Sp_BtnRepair_UpdateLogSlavePrice (procedure)
重新计算物流单从表金额
- Type: PROCEDURE
- Deterministic: NO
- SQL data access: CONTAINS SQL
Parameters
| # | Mode | Name | Type |
|---|---|---|---|
| 1 | IN | sProInParam |
varchar(10000) |
| 2 | IN | sMakePerson |
varchar(100) |
| 3 | IN | sUserId |
varchar(100) |
| 4 | IN | sBrId |
varchar(100) |
| 5 | IN | sSuId |
varchar(100) |
| 6 | OUT | sReturn |
varchar(1000) |
| 7 | OUT | sCode |
int |
Body
Body is not pre-cached. To inspect: mysql --defaults-file=~/.my.cnf -e 'SHOW CREATE PROCEDURESpBtnRepair_UpdateLogSlavePrice'._
Narrative
Business context: 物流单 / 重新计算物流单从表金额 — bulk "批量修改" dialog handler that recalculates logisticsorderslave per-line material money/price by allocating the master total proportionally to a chosen base (product price × auxiliary qty, or materials price × auxiliary qty), rather than per-line manual entry.
What it does: For each master sId in the payload, runs a multi-step recalc on logisticsorderslave: (1) populate dSrcMoney from a fallback chain (B.dProductPrice * A.dAuxiliaryQty, then B.dMaterialsPrice * A.dAuxiliaryQty); (2) sum dSrcMoney into p_dSrcTotalMoney and dProductMoney into p_dTotalMoney; (3) re-distribute dMaterialsMoney = ROUND(dSrcMoney / p_dSrcTotalMoney * p_dTotalMoney, 2) and back-derive dMaterialsPrice per line.
Invocation: Dispatched dynamically by GenericProcedureCallServiceImpl.doGenericProcedureCall() (POST /procedureCall/doGenericProcedureCall) — front-end "重新计算金额" dialog on the 物流单 grid registers this procedure name. Built from the sButtonParam.sql template; only the textareaValue memo is parsed from changeValue (no per-field values).