SaveBedNetVarExcutor.cs 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  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 SaveBedNetVarExcutor : ExcutorBase<SaveBedNetVarRequest, SaveBedNetVarResponse>
  15. {
  16. protected override void ExcuteInternal(SaveBedNetVarRequest request, object state, SaveBedNetVarResponse rslt)
  17. {
  18. var tokendata = BllHelper.GetToken(request.token);
  19. if (tokendata == null)
  20. {
  21. rslt.ErrMsg = "会话已经中断,请重新登录";
  22. return;
  23. }
  24. if (request.bednetvar == null)
  25. {
  26. rslt.ErrMsg = "未提交弹簧资料";
  27. return;
  28. }
  29. if (string.IsNullOrEmpty(request.bednetvar.varname))
  30. {
  31. rslt.ErrMsg = "请录入名称";
  32. return;
  33. }
  34. using (var con = new SqlConnection(GlobalVar.ConnectionString))
  35. using (var cmd = con.CreateCommand())
  36. {
  37. con.Open();
  38. var dtNow = DateTime.Now;
  39. AutoInit.AutoInitS(cmd, request.bednetvar);
  40. using (cmd.Transaction = con.BeginTransaction())
  41. {
  42. try
  43. {
  44. if (request.bednetvar.varid <= 0)
  45. {
  46. request.bednetvar.varid = BllHelper.GetID(cmd, "u_bednet_var");
  47. request.bednetvar.createtime = dtNow;
  48. request.bednetvar.createby = tokendata.username;
  49. var fields = @"varid,varkind,varcode,varname,varclass,vartype,varunit,varvalue,dscrp,createtime,createby,formula";
  50. DbSqlHelper.Insert(cmd, "u_bednet_var", null, request.bednetvar, fields);
  51. }
  52. else
  53. {
  54. //修改
  55. var fields = @"varcode,varname,varclass,vartype,varunit,varvalue,dscrp,formula";
  56. DbSqlHelper.Update(cmd, "u_bednet_var", null, request.bednetvar, "varid", fields);
  57. }
  58. if(request.bednetvar.mxlist != null && request.bednetvar.mxlist.Any())
  59. {
  60. // 新增明细
  61. foreach (var item in request.bednetvar.mxlist)
  62. {
  63. AutoInit.AutoInitS(cmd, item);
  64. if (item.varmxid <= 0)
  65. {
  66. item.varmxid = BllHelper.GetID(cmd, "u_bednet_varmx");
  67. item.varid = request.bednetvar.varid;
  68. var fields = @"varmxid,varid,line_diameter,bednettypeid,varvalue,pricelistid,formula";
  69. DbSqlHelper.Insert(cmd, "u_bednet_varmx", null, item, fields);
  70. } else
  71. {
  72. //修改
  73. var fields = @"line_diameter,bednettypeid,varvalue,formula";
  74. DbSqlHelper.Update(cmd, "u_bednet_varmx", null, item, "varmxid", fields);
  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. }