SaveMultiPriceExcutor.cs 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  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 SaveMultiPriceExcutor : ExcutorBase<SaveMultiPriceRequest, SaveMultiPriceResponse>
  16. {
  17. protected override void ExcuteInternal(SaveMultiPriceRequest request, object state, SaveMultiPriceResponse rslt)
  18. {
  19. var tokendata = BllHelper.GetToken(request.token);
  20. if (tokendata == null)
  21. {
  22. rslt.ErrMsg = "会话已经中断,请重新登录";
  23. return;
  24. }
  25. if (request.price == null)
  26. {
  27. rslt.ErrMsg = "未提交多维度定价资料";
  28. return;
  29. }
  30. if (request.price.coefficient == null)
  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.price);
  41. using (cmd.Transaction = con.BeginTransaction())
  42. {
  43. try
  44. {
  45. if (request.price.multipriceid <= 0)
  46. {
  47. request.price.multipriceid = BllHelper.GetID(cmd, "u_multiprice");
  48. var fields = @"multipriceid,coefficient,price_formula,dscrp,inuse";
  49. DbSqlHelper.Insert(cmd, "u_multiprice", null, request.price, fields);
  50. }
  51. else
  52. {
  53. //修改
  54. var fields = @"coefficient,price_formula,dscrp,inuse";
  55. DbSqlHelper.Update(cmd, "u_multiprice", null, request.price, "multipriceid", fields);
  56. }
  57. cmd.Transaction.Commit();
  58. }
  59. catch (Exception e)
  60. {
  61. cmd.Transaction.Rollback();
  62. rslt.ErrMsg = e.ToString();
  63. }
  64. }
  65. }
  66. }
  67. }
  68. }