SaveMtrlDefExcutor.cs 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  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 SaveMtrlDefExcutor : ExcutorBase<SaveMtrlDefRequest, SaveMtrlDefResponse>
  16. {
  17. protected override void ExcuteInternal(SaveMtrlDefRequest request, object state, SaveMtrlDefResponse rslt)
  18. {
  19. var tokendata = BllHelper.GetToken(request.token);
  20. if (tokendata == null)
  21. {
  22. rslt.ErrMsg = "会话已经中断,请重新登录";
  23. return;
  24. }
  25. if (request.mtrl == null)
  26. {
  27. rslt.ErrMsg = "未提交物料类别定义";
  28. return;
  29. }
  30. if (string.IsNullOrEmpty(request.mtrl.name))
  31. {
  32. rslt.ErrMsg = "请输入物料名称";
  33. return;
  34. }
  35. using (var con = GlobalVar.ConnectionString.NewSqlConnection())
  36. using (var cmd = con.CreateCommand())
  37. {
  38. con.Open();
  39. var dtNow = DateTime.Now;
  40. AutoInit.AutoInitS(cmd, request.mtrl);
  41. using (cmd.Transaction = con.BeginTransaction())
  42. {
  43. try
  44. {
  45. if (request.mtrl.mtrlid <= 0)
  46. {
  47. request.mtrl.mtrlid = BllHelper.GetID(cmd, "u_mtrl_price");
  48. request.mtrl.createtime = dtNow;
  49. request.mtrl.createby = tokendata.username;
  50. var fields = @"mtrlid,mtrltype,name,priceunit,shrinkage,gram_weight,cloth_width,if_inputqty,if_areaprice,createtime,createby,thickness,dscrp,erp_mtrlid,fjcnt,isuse,handtype,lastdate,erp_mtrlengname,if_subspecs,extra_cost";
  51. DbSqlHelper.Insert(cmd, "u_mtrl_price", null, request.mtrl, fields);
  52. var fields2 = @"mtrlid,pricelistid,price,pricetype,price_formula,qty_formula";
  53. if(request.mtrl.mxlist != null && request.mtrl.mxlist.Any())
  54. {
  55. foreach (var mx in request.mtrl.mxlist)
  56. {
  57. AutoInit.AutoInitS(cmd, mx);
  58. mx.mtrlid = request.mtrl.mtrlid;
  59. DbSqlHelper.Insert(cmd, "u_mtrl_price_pricelist", null, mx, fields2);
  60. }
  61. }
  62. }
  63. else
  64. {
  65. //修改
  66. var fields = @"mtrltype,name,priceunit,shrinkage,gram_weight,cloth_width,if_inputqty,if_areaprice,thickness,dscrp,erp_mtrlid,fjcnt,isuse,handtype,lastdate,erp_mtrlengname,if_subspecs,extra_cost";
  67. DbSqlHelper.Update(cmd, "u_mtrl_price", null, request.mtrl, "mtrlid", fields);
  68. var fields2 = @"price,pricetype,price_formula,qty_formula";
  69. if (request.mtrl.mxlist != null && request.mtrl.mxlist.Any())
  70. {
  71. foreach (var mx in request.mtrl.mxlist)
  72. {
  73. AutoInit.AutoInitS(cmd, mx);
  74. DbSqlHelper.Update(cmd, "u_mtrl_price_pricelist", null, mx, "mtrlid,pricelistid", fields2);
  75. }
  76. }
  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. }