SaveShrinkageExcutor.cs 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  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.LJException;
  9. using JLHHJSvr.Tools;
  10. using LJLib.DAL.SQL;
  11. using LJLib.Net.SPI.Server;
  12. namespace JLHHJSvr.Excutor
  13. {
  14. internal sealed class SaveShrinkageExcutor : ExcutorBase<SaveShrinkageRequest, SaveShrinkageResponse>
  15. {
  16. protected override void ExcuteInternal(SaveShrinkageRequest request, object state, SaveShrinkageResponse rslt)
  17. {
  18. var tokendata = BllHelper.GetToken(request.token);
  19. if (tokendata == null)
  20. {
  21. rslt.ErrMsg = "会话已经中断,请重新登录";
  22. return;
  23. }
  24. if (request.shrinkage == null)
  25. {
  26. rslt.ErrMsg = "未提交裥棉收缩率";
  27. return;
  28. }
  29. using (var con = new SqlConnection(GlobalVar.ConnectionString))
  30. using (var cmd = con.CreateCommand())
  31. {
  32. con.Open();
  33. var dtNow = DateTime.Now;
  34. AutoInit.AutoInitS(cmd, request.shrinkage);
  35. if (request.shrinkage.minvalue > request.shrinkage.maxvalue)
  36. {
  37. rslt.ErrMsg = "裥棉收缩率错误,下限不能大于上限!";
  38. return;
  39. }
  40. using (cmd.Transaction = con.BeginTransaction())
  41. {
  42. try
  43. {
  44. if (request.shrinkage.shrinkageid <= 0)
  45. {
  46. request.shrinkage.shrinkageid = BllHelper.GetID(cmd, "u_shrinkage");
  47. request.shrinkage.createtime = dtNow;
  48. request.shrinkage.createby = tokendata.username;
  49. var fields = @"shrinkageid,minvalue,maxvalue,shrinkage,createtime,createby";
  50. DbSqlHelper.Insert(cmd, "u_shrinkage", null, request.shrinkage, fields);
  51. }
  52. else
  53. {
  54. //修改
  55. var fields = @"minvalue,maxvalue,shrinkage";
  56. DbSqlHelper.Update(cmd, "u_shrinkage", null, request.shrinkage, "shrinkageid", fields);
  57. }
  58. cmd.Transaction.Commit();
  59. }
  60. catch (Exception e)
  61. {
  62. cmd.Transaction.Rollback();
  63. rslt.ErrMsg = e.ToString();
  64. }
  65. }
  66. }
  67. }
  68. }
  69. }