ReCalculateERPCostExcutor.cs 4.4 KB

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