SaveWorkmanshipExcutor.cs 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  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. using LJLib.SQLEX;
  13. namespace JLHHJSvr.Excutor
  14. {
  15. internal sealed class SaveWorkmanshipExcutor : ExcutorBase<SaveWorkmanshipRequest, SaveWorkmanshipResponse>
  16. {
  17. protected override void ExcuteInternal(SaveWorkmanshipRequest request, object state, SaveWorkmanshipResponse rslt)
  18. {
  19. var tokendata = BllHelper.GetToken(request.token);
  20. if (tokendata == null)
  21. {
  22. rslt.ErrMsg = "会话已经中断,请重新登录";
  23. return;
  24. }
  25. if (request.workmanship == null)
  26. {
  27. rslt.ErrMsg = "未提交工艺加点设置信息";
  28. return;
  29. }
  30. foreach(var item in request.workmanship)
  31. {
  32. if (item.rate < 0)
  33. {
  34. rslt.ErrMsg = "利润率有误,请检查!";
  35. return;
  36. }
  37. }
  38. using (var con = GlobalVar.ConnectionString.NewSqlConnection())
  39. using (var cmd = con.CreateCommand())
  40. {
  41. con.Open();
  42. var dtNow = DateTime.Now;
  43. AutoInit.AutoInitS(cmd, request.workmanship);
  44. using (cmd.Transaction = con.BeginTransaction())
  45. {
  46. try
  47. {
  48. foreach (var item in request.workmanship)
  49. {
  50. if (item.workmanshipid <= 0)
  51. {
  52. item.workmanshipid = BllHelper.GetID(cmd, "u_workmanship_add");
  53. var fields = "workmanshipid,deptid,mattresstypeid,workmanshipname,formula,rate";
  54. DbSqlHelper.Insert(cmd, "u_workmanship_add", null, item, fields);
  55. }
  56. else
  57. {
  58. //修改
  59. var fields = "deptid,mattresstypeid,formula,rate";
  60. DbSqlHelper.Update(cmd, "u_workmanship_add", null, item, "workmanshipid", fields);
  61. }
  62. }
  63. cmd.Transaction.Commit();
  64. }
  65. catch (Exception e)
  66. {
  67. cmd.Transaction.Rollback();
  68. rslt.ErrMsg = e.ToString();
  69. }
  70. }
  71. }
  72. }
  73. }
  74. }