| | |
| | | private static string GenerateOrderNo(string snType, string prefix) { |
| | | var id = SYSHelper.GetSerialNumber(snType, prefix); |
| | | var date = DateTime.Now.ToString("yyMMdd"); |
| | | return $"{prefix}{date}{id.ToString().PadLeft(4, '0')}"; |
| | | return $"{prefix}{date}-{id.ToString().PadLeft(4, '0')}"; |
| | | } |
| | | |
| | | /// <summary> |
| | |
| | | var info = ""; |
| | | try { |
| | | // 参数合法性确认部分:错误编码:400 |
| | | if (model.pzsl <= 0) { |
| | | info = $"物料数量(pzsl){model.pzsl}不合法:物料数量应该大于 0"; |
| | | if (model.pzjs <= 0) { |
| | | info = $"物料数量(pzjs){model.pzjs}不合法:物料数量应该大于 0"; |
| | | LogHelper.Info(info); |
| | | return NewErpResult(400, info); |
| | | } |
| | | |
| | | var outboundPlan = new TN_Outbound_Plan { |
| | | var outboundPlan = db.Queryable<TN_Outbound_Plan>() |
| | | .Where(p => p.JHDH == model.jhdh).First(); |
| | | if (outboundPlan != null) { |
| | | info = $"计划单号{model.jhdh}已在数据库中存在"; |
| | | LogHelper.Info(info); |
| | | return NewErpResult(1, info); |
| | | } |
| | | |
| | | outboundPlan = new TN_Outbound_Plan { |
| | | JHDH = model.jhdh, // 计划单号(唯一标识) |
| | | CKZT = model.ckzt, // 出库状态 |
| | | CKZT = model.ckzt, // 出库状态(需要返回) |
| | | JHLB = model.jhlb, // 计划类别 |
| | | CKDH = model.ckdh, // 参考单号 |
| | | CPH = model.cph, // 车牌号 |
| | |
| | | CPLB = model.cplb, // 产品类别 |
| | | CPLBMX = model.cplbmx, // 产品类别明细 |
| | | PP = model.pp, // 品牌 |
| | | DJ = model.dj, // 等级 |
| | | DJ = model.dj, // 等级(需要返回) |
| | | GH = model.gh, // 罐号 |
| | | PH = model.ph, // 批号 |
| | | PH = model.ph, // 批号(需要返回) |
| | | BZLX = model.bzlx, // 包装类型 |
| | | PZDH = model.pzdh, // 派装单号 |
| | | PZD_DW = model.pzd_dw, // 派装单单位 |
| | |
| | | PZ_ZFRQ = model.pz_zfrq, // 派装作废日期 |
| | | PZ_BZ = model.pz_bz, // 派装备注 |
| | | CKDBH = model.ckdbh, // 出库单编号 |
| | | SFJS = model.sfjs, // 实发件数 |
| | | SFSL = model.sfsl, // 实发数量 |
| | | SFCS = model.sfcs, // 实发车数 |
| | | ZCSJ = model.zcsj, // 装车时间 |
| | | JLDW = model.jldw, // 计量单位 |
| | | FHRQ = model.fhrq, // 发货日期 |
| | | CKDM = model.ckdm, // 仓库代码 |
| | | FHR = model.fhr, // 发货人 |
| | | CZYDM = model.czydm, // 操作员 |
| | | SFJS = model.sfjs, // 实发件数(需要返回) |
| | | SFSL = model.sfsl, // 实发数量(需要返回) |
| | | SFCS = model.sfcs, // 实发车数(需要返回) |
| | | ZCSJ = model.zcsj, // 装车时间(需要返回) |
| | | JLDW = model.jldw, // 计量单位(需要返回) |
| | | FHRQ = model.fhrq, // 发货日期(需要返回) |
| | | CKDM = model.ckdm, // 仓库代码(需要返回) |
| | | FHR = model.fhr, // 发货人(需要返回) |
| | | CZYDM = model.czydm, // 操作员(需要返回) |
| | | SHR_USERNAME = model.shr_username, // 审核人 |
| | | SHRQ = model.shrq, // 审核日期 |
| | | ZFBJ = model.zfbj, // 作废标记 |
| | |
| | | SHDW = model.shdw, // 收货单位 |
| | | YSDW = model.ysdw, // 运输单位 |
| | | LXR = model.lxr, // 联系人 |
| | | RY_ZXG = model.ry_zxg, // 装卸工 |
| | | RY_CCSJ = model.ry_ccsj, // 叉车司机 |
| | | RY_ZXG = model.ry_zxg, // 装卸工(需要返回) |
| | | RY_CCSJ = model.ry_ccsj, // 叉车司机(需要返回) |
| | | ERPHX_JHDH = model.erphx_jhdh, // erp交货单号 |
| | | ERPHX_WLBM = model.erphx_wlbm, // erp物料编码 |
| | | ERPHX_WLMC = model.erphx_wlmc, // erp物料名称 |
| | | ERPHX_CJRQ = model.erphx_cjrq, // erp创建日期 |
| | | HW = model.hw, // 货位 |
| | | HWZT = model.hwzt // 货位状态 |
| | | HW = model.hw, // 货位(需要返回) |
| | | HWZT = model.hwzt // 货位状态(需要返回) |
| | | }; |
| | | |
| | | var cgDetailList = SelectCgByTotalQty( |
| | | qty: (int)model.pzsl, |
| | | itemCode: model.cpdm, |
| | | batchNo: model.ph |
| | | ); |
| | | //var cgDetailList = SelectCgByTotalQty( |
| | | // qty: (int)model.pzsl, |
| | | // itemCode: model.cpdm, |
| | | // batchNo: model.ph |
| | | // ); |
| | | |
| | | if (cgDetailList.Count == 0) { |
| | | info = "没有合适的物料可以出库"; |
| | | //if (cgDetailList.Count == 0) { |
| | | // info = "没有合适的物料可以出库"; |
| | | // LogHelper.Info(info); |
| | | // return NewErpResult(3, info); |
| | | //} |
| | | |
| | | var cgDetail = db.Queryable<TN_CG_Detail>() |
| | | .Where(d => d.S_ITEM_CODE == model.cpdm && d.N_ITEM_NUM >= model.pzjs).First(); |
| | | if (cgDetail == null ) { |
| | | info = $"没有合适的物料可以满足:物料编码={model.cpdm},物料数量>={model.pzjs}"; |
| | | LogHelper.Info(info); |
| | | return NewErpResult(3, info); |
| | | return NewErpResult(2, info); |
| | | } |
| | | |
| | | var order = new TN_Outbound_Order { |
| | | S_NO = orderNo, |
| | | //S_ITEM_CODE = model.cpdm, |
| | | //S_BATCH = model.ph, |
| | | //N_END_NUM = (int)model.pzsl, |
| | | S_ITEM_CODE = model.cpdm, |
| | | S_BATCH = model.ph, |
| | | N_END_NUM = (int)model.pzsl, |
| | | //F_OUT_QTY = cgDetailList.Sum(a => a.N_QTY), |
| | | S_END_AREA = model.ysfs == "汽车" ? "QCCKQ" : "HCCKQ", // 暂时用运输方式(火车/汽车)来区分终点货区 |
| | | S_BATCH = cgDetail.S_BATCH_NO, |
| | | N_END_NUM = (int)model.pzjs, |
| | | S_END_AREA = "QCCKQ", // ERP下发出库任务为汽车出库区 |
| | | S_BS_NO = model.jhdh, |
| | | S_BS_TYPE = "ERP", |
| | | }; |
| | | |
| | | var detailList = new List<TN_Outbound_Detail>(); |
| | | foreach (var cgDetail in cgDetailList) { |
| | | var detail = new TN_Outbound_Detail { |
| | | S_OO_NO = orderNo, |
| | | S_ITEM_CODE = cgDetail.S_ITEM_CODE, |
| | | S_BATCH_NO = cgDetail.S_BATCH_NO, |
| | | S_CNTR_CODE = cgDetail.S_CNTR_CODE, |
| | | N_COUNT = cgDetail.N_ITEM_NUM, |
| | | S_END_AREA = order.S_END_AREA, // order为detail的每一个货位设置终点值 |
| | | S_BS_NO = order.S_BS_NO, |
| | | S_BS_TYPE= order.S_BS_TYPE, |
| | | }; |
| | | detailList.Add(detail); |
| | | } |
| | | //foreach (var cgDetail in cgDetailList) { |
| | | // var detail = new TN_Outbound_Detail { |
| | | // S_OO_NO = orderNo, |
| | | // S_ITEM_CODE = cgDetail.S_ITEM_CODE, |
| | | // S_BATCH_NO = cgDetail.S_BATCH_NO, |
| | | // S_CNTR_CODE = cgDetail.S_CNTR_CODE, |
| | | // N_COUNT = cgDetail.N_ITEM_NUM, |
| | | // S_END_AREA = order.S_END_AREA, // order为detail的每一个货位设置终点值 |
| | | // S_BS_NO = order.S_BS_NO, |
| | | // S_BS_TYPE= order.S_BS_TYPE, |
| | | // }; |
| | | // detailList.Add(detail); |
| | | //} |
| | | var detail = new TN_Outbound_Detail { |
| | | S_OO_NO = orderNo, |
| | | S_ITEM_CODE = cgDetail.S_ITEM_CODE, |
| | | S_BATCH_NO = cgDetail.S_BATCH_NO, |
| | | S_CNTR_CODE = cgDetail.S_CNTR_CODE, |
| | | N_COUNT = cgDetail.N_ITEM_NUM, |
| | | S_END_AREA = order.S_END_AREA, // order为detail的每一个货位设置终点值 |
| | | S_BS_NO = order.S_BS_NO, |
| | | S_BS_TYPE = order.S_BS_TYPE, |
| | | }; |
| | | detailList.Add(detail); |
| | | |
| | | using (var tran = db.Ado.UseTran()) { |
| | | if (db.Insertable<TN_Outbound_Order>(order).ExecuteCommand() <= 0) { |
| | |
| | | tran.CommitTran(); |
| | | } |
| | | |
| | | info = $"生成出库单成功"; |
| | | info = $"生成出库单成功:" + JsonConvert.SerializeObject(order) + "\n出库单明细:" +JsonConvert.SerializeObject(detail); |
| | | LogHelper.Info(info); |
| | | return NewErpResult(0, info); |
| | | } |