SaveConfigureCodeMxExcutor.cs 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  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 SaveConfigureCodeMxExcutor : ExcutorBase<SaveConfigureCodeMxRequest, SaveConfigureCodeMxResponse>
  16. {
  17. protected override void ExcuteInternal(SaveConfigureCodeMxRequest request, object state, SaveConfigureCodeMxResponse rslt)
  18. {
  19. var tokendata = BllHelper.GetToken(request.token);
  20. if (tokendata == null)
  21. {
  22. rslt.ErrMsg = "会话已经中断,请重新登录";
  23. return;
  24. }
  25. if (request.configure == null)
  26. {
  27. rslt.ErrMsg = "未提交部件选配项";
  28. return;
  29. }
  30. if (string.IsNullOrEmpty(request.configure.pzcodemx))
  31. {
  32. rslt.ErrMsg = "请输入明细编号";
  33. return;
  34. }
  35. if (string.IsNullOrEmpty(request.configure.namemx))
  36. {
  37. rslt.ErrMsg = "请输入明细名称";
  38. return;
  39. }
  40. if (request.configure.pzid <= 0)
  41. {
  42. rslt.ErrMsg = "部件选配配置id错误";
  43. return;
  44. }
  45. using (var con = GlobalVar.ConnectionString.NewSqlConnection())
  46. using (var cmd = con.CreateCommand())
  47. {
  48. con.Open();
  49. var dtNow = DateTime.Now;
  50. AutoInit.AutoInitS(cmd, request.configure);
  51. using (cmd.Transaction = con.BeginTransaction())
  52. {
  53. try
  54. {
  55. if (request.configure.printid <= 0)
  56. {
  57. int _printid = 0;
  58. cmd.CommandText = @"SELECT MAX(printid) AS printid FROM u_configure_codemx WHERE pzid = @pzid";
  59. cmd.Parameters.Clear();
  60. cmd.Parameters.AddWithValue("@pzid", request.configure.pzid);
  61. using (var reader = cmd.ExecuteReader())
  62. {
  63. if (reader.Read())
  64. {
  65. _printid = Convert.ToInt32(reader["printid"]);
  66. }
  67. }
  68. request.configure.printid = _printid + 1;
  69. var fields = @"pzid,printid,pzcodemx,namemx,gradestr,mtrlcode,price,ifdft,MCostRate,ProfitRate,dscrp,ifuse,ifnoch,pricerate,packqty,packvol,price_pz,grade";
  70. DbSqlHelper.Insert(cmd, "u_configure_codemx", null, request.configure, fields);
  71. }
  72. else
  73. {
  74. //修改
  75. var fields = @"pzcodemx,namemx,gradestr,mtrlcode,price,ifdft,MCostRate,ProfitRate,dscrp,ifuse,ifnoch,pricerate,packqty,packvol,price_pz,grade";
  76. DbSqlHelper.Update(cmd, "u_configure_codemx", null, request.configure, "pzid,printid", fields);
  77. }
  78. cmd.Transaction.Commit();
  79. }
  80. catch (Exception e)
  81. {
  82. cmd.Transaction.Rollback();
  83. rslt.ErrMsg = e.ToString();
  84. }
  85. }
  86. }
  87. }
  88. }
  89. }