SaveMattressExcutor.cs 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  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. namespace JLHHJSvr.Excutor
  15. {
  16. internal sealed class SaveMattressExcutor : ExcutorBase<SaveMattressRequest, SaveMattressResponse>
  17. {
  18. protected override void ExcuteInternal(SaveMattressRequest request, object state, SaveMattressResponse rslt)
  19. {
  20. var tokendata = BllHelper.GetToken(request.token);
  21. if (tokendata == null)
  22. {
  23. rslt.ErrMsg = "会话已经中断,请重新登录";
  24. return;
  25. }
  26. if (request.mattress == null)
  27. {
  28. rslt.ErrMsg = "缺少主表信息";
  29. return;
  30. }
  31. using (var con = new SqlConnection(GlobalVar.ConnectionString))
  32. using (var cmd = con.CreateCommand())
  33. {
  34. con.Open();
  35. // 初始化属性
  36. AutoInit.AutoInitS(cmd, request.mattress);
  37. if(request.mattress.copy_id != null && request.mattress.copy_id > 0)
  38. {
  39. request.mattress.mattressid = 0;
  40. request.mattress.mattresscode = string.Empty;
  41. foreach (var mx in request.mattressMx)
  42. {
  43. mx.mattressid = 0;
  44. mx.mattressmxid = 0;
  45. }
  46. }
  47. foreach(var mx in request.mattressMx)
  48. {
  49. AutoInit.AutoInitS(cmd, mx);
  50. }
  51. using (cmd.Transaction = con.BeginTransaction())
  52. {
  53. var helper = HelperBase.GetHelper<MattressHelper>(cmd, new HelperBase.Context() { tokendata = tokendata });
  54. try
  55. {
  56. helper.CalCulateFormula(request.mattress, request.mattressMx);
  57. }
  58. catch (Exception e)
  59. {
  60. rslt.message = e.Message;
  61. }
  62. var mxmessageList = request.mattressMx.Where(item => !string.IsNullOrEmpty(item.message)).ToList();
  63. if (mxmessageList.Any())
  64. {
  65. rslt.mxmessage = new List<string>();
  66. foreach (var mx in mxmessageList)
  67. {
  68. rslt.mxmessage.Add(mx.message);
  69. }
  70. }
  71. try
  72. {
  73. helper.SaveMattress(request.mattress, request.mattressMx);
  74. if(request.mattress.copy_id != null && request.mattress.copy_id > 0)
  75. {
  76. helper.CopyMattressInterface(request.mattress.copy_id.Value, request.mattress.mattressid);
  77. }
  78. cmd.Transaction.Commit();
  79. rslt.mattressid = request.mattress.mattressid;
  80. rslt.mattresscode = request.mattress.mattresscode;
  81. }
  82. catch (Exception e)
  83. {
  84. cmd.Transaction.Rollback();
  85. rslt.ErrMsg = e.Message;
  86. }
  87. }
  88. }
  89. }
  90. }
  91. }