SaveProfitrateExcutor.cs 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  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 SaveProfitrateExcutor : ExcutorBase<SaveProfitrateRequest, SaveProfitrateResponse>
  15. {
  16. protected override void ExcuteInternal(SaveProfitrateRequest request, object state, SaveProfitrateResponse rslt)
  17. {
  18. var tokendata = BllHelper.GetToken(request.token);
  19. if (tokendata == null)
  20. {
  21. rslt.ErrMsg = "会话已经中断,请重新登录";
  22. return;
  23. }
  24. if (!request.list.Any())
  25. {
  26. rslt.ErrMsg = "未提交工厂利润率信息";
  27. return;
  28. }
  29. foreach(var profitrate in request.list)
  30. {
  31. if (profitrate.profitrate < 0)
  32. {
  33. rslt.ErrMsg = "利润率有误,请检查!";
  34. return;
  35. }
  36. }
  37. using (var con = new SqlConnection(GlobalVar.ConnectionString))
  38. using (var cmd = con.CreateCommand())
  39. {
  40. con.Open();
  41. var dtNow = DateTime.Now;
  42. using (cmd.Transaction = con.BeginTransaction())
  43. {
  44. try
  45. {
  46. foreach (var profitrate in request.list)
  47. {
  48. cmd.CommandText = @"SELECT COUNT(*) AS cnt
  49. FROM u_factory_profitrate
  50. WHERE u_factory_profitrate.deptid = @deptid
  51. AND u_factory_profitrate.bednettypeid_mattresstypeid = @typid
  52. AND u_factory_profitrate.bednet_or_mattress = @kind";
  53. cmd.Parameters.Clear();
  54. cmd.Parameters.AddWithValue("@deptid", profitrate.deptid);
  55. cmd.Parameters.AddWithValue("@typid", profitrate.bednettypeid_mattresstypeid);
  56. cmd.Parameters.AddWithValue("@kind", profitrate.bednet_or_mattress);
  57. var cnt = Convert.ToInt32(cmd.ExecuteScalar());
  58. if (cnt <= 0)
  59. {
  60. AutoInit.AutoInitS(cmd, profitrate);
  61. profitrate.createtime = dtNow;
  62. profitrate.createby = tokendata.username;
  63. var fields = "deptid,bednet_or_mattress,bednettypeid_mattresstypeid,createtime,profitrate,createby";
  64. DbSqlHelper.Insert(cmd, "u_factory_profitrate", null, profitrate, fields);
  65. }
  66. else
  67. {
  68. //修改
  69. var fields = "profitrate";
  70. DbSqlHelper.Update(cmd, "u_factory_profitrate", null, profitrate, "deptid,bednet_or_mattress,bednettypeid_mattresstypeid", fields);
  71. }
  72. }
  73. cmd.Transaction.Commit();
  74. }
  75. catch (Exception e)
  76. {
  77. cmd.Transaction.Rollback();
  78. rslt.ErrMsg = e.ToString();
  79. }
  80. }
  81. }
  82. }
  83. }
  84. }