ReCalculateERPCostExcutor.cs 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.SqlClient;
  4. using System.Diagnostics;
  5. using System.Linq;
  6. using System.Text;
  7. using JLHHJSvr.BLL;
  8. using JLHHJSvr.Com;
  9. using JLHHJSvr.Com.Model;
  10. using JLHHJSvr.Helper;
  11. using JLHHJSvr.LJException;
  12. using JLHHJSvr.Tools;
  13. using LJLib.DAL.SQL;
  14. using LJLib.Net.SPI.Server;
  15. using LJLib.SQLEX;
  16. using NPOI.OpenXml4Net.OPC.Internal;
  17. using static JLHHJSvr.Helper.CacheHelper;
  18. namespace JLHHJSvr.Excutor
  19. {
  20. internal sealed class ReCalculateERPCostExcutor : ExcutorBase<ReCalculateERPCostRequest, ReCalculateERPCostResponse>
  21. {
  22. protected override void ExcuteInternal(ReCalculateERPCostRequest request, object state, ReCalculateERPCostResponse rslt)
  23. {
  24. var tokendata = BllHelper.GetToken(request.token);
  25. if (tokendata == null)
  26. {
  27. rslt.ErrMsg = "会话已经中断,请重新登录";
  28. return;
  29. }
  30. if (request.list == null)
  31. {
  32. rslt.ErrMsg = "提交缺少列表参数,请检查!";
  33. return;
  34. }
  35. if (!request.list.Any())
  36. {
  37. rslt.ErrMsg = "至少提交一条需要重算的记录";
  38. return;
  39. }
  40. using (var con = GlobalVar.ConnectionString.NewSqlConnection())
  41. using (var cmd = con.CreateCommand())
  42. {
  43. con.Open();
  44. var log_sb = new StringBuilder();
  45. var logerr_sb = new StringBuilder();
  46. var helper = HelperBase.GetHelper<MattressHelper>(cmd, new HelperBase.Context() { tokendata = tokendata });
  47. var l1Helper = HelperBase.GetHelper<ERPHelper>(cmd, new HelperBase.Context() { tokendata = tokendata });
  48. foreach (var mattress in request.list)
  49. {
  50. DbSqlHelper.SelectOne(cmd, mattress, "flag,deptid");
  51. //if (mattress.flag == 1) throw new LJCommonException("存在报价单已审核,不能重算!");
  52. if (mattress.deptid <= 0) throw new LJCommonException("存在报价单部门id错误,不能重算!");
  53. var dept = helper.Cache.GetData<int,u_dept,DeptMapping>(mattress.deptid.Value);
  54. if (dept.pricelistid <= 0) throw new LJCommonException("存在报价单部门pricelistid错误,不能重算!");
  55. }
  56. using (cmd.Transaction = con.BeginTransaction())
  57. {
  58. try
  59. {
  60. foreach (var mattress in request.list)
  61. {
  62. var mattress_temp = helper.GetMattress(mattress.mattressid);
  63. var mxList = helper.GetMattressMxMtrl(mattress.mattressid);
  64. var mxExtra1List = helper.GetMattressMxExtra(mattress.mattressid, 1);
  65. var mxExtra2List = helper.GetMattressMxExtra(mattress.mattressid, 2);
  66. var subspecsList = helper.GetMattressSubspecs(mattress.mattressid);
  67. try
  68. {
  69. helper.MattressCalculateCost(mattress_temp, mxList, mxExtra1List, mxExtra2List);
  70. helper.SaveMattress(mattress_temp, mxList, mxExtra1List, mxExtra2List);
  71. if (mattress_temp.erp_mtrlid > 0)
  72. {
  73. string errmsg = l1Helper.SaveMtrldef(mattress_temp, null, "GYAuditdate");
  74. if (!string.IsNullOrEmpty(errmsg)) throw new LJCommonException(errmsg);
  75. }
  76. //cmd.Transaction.Commit();
  77. log_sb.Append($"床垫唯一码:{mattress_temp.mattresscode}重算成功\r\n");
  78. }
  79. catch (Exception ex)
  80. {
  81. //cmd.Transaction.Rollback();
  82. Trace.Write($"ReCalculateERPCost : {ex.ToString()}");
  83. logerr_sb.Append($"床垫唯一码:{mattress_temp.mattresscode}重算失败,错误:{ex.Message}\r\n");
  84. }
  85. }
  86. if (logerr_sb.Length > 0) throw new LJCommonException(logerr_sb.ToString());
  87. cmd.Transaction.Commit();
  88. }
  89. catch (Exception ex)
  90. {
  91. cmd.Transaction.Rollback();
  92. }
  93. if (log_sb.Length > 0 || logerr_sb.Length > 0) rslt.logMsg = log_sb.Append(logerr_sb.ToString()).ToString();
  94. }
  95. }
  96. }
  97. }
  98. }