SaveDeptExcutor.cs 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  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 SaveDeptExcutor : ExcutorBase<SaveDeptRequest, SaveDeptResponse>
  15. {
  16. protected override void ExcuteInternal(SaveDeptRequest request, object state, SaveDeptResponse rslt)
  17. {
  18. var tokendata = BllHelper.GetToken(request.token);
  19. if (tokendata == null)
  20. {
  21. rslt.ErrMsg = "会话已经中断,请重新登录";
  22. return;
  23. }
  24. if (request.dept == null)
  25. {
  26. rslt.ErrMsg = "未提交部门信息";
  27. return;
  28. }
  29. if (string.IsNullOrEmpty(request.dept.deptname))
  30. {
  31. rslt.ErrMsg = "请录入部门名称!";
  32. return;
  33. }
  34. if (request.dept.pricelistid == null || request.dept.pricelistid <= 0)
  35. {
  36. rslt.ErrMsg = "请选择价格表!";
  37. return;
  38. }
  39. using (var con = new SqlConnection(GlobalVar.ConnectionString))
  40. using (var cmd = con.CreateCommand())
  41. {
  42. con.Open();
  43. cmd.CommandText = @"SELECT COUNT(deptname) AS cnt FROM u_dept WHERE deptname = @deptname";
  44. cmd.Parameters.Clear();
  45. cmd.Parameters.AddWithValue("@deptname", request.dept.deptname);
  46. var cnt = Convert.ToInt32(cmd.ExecuteScalar());
  47. if (cnt > 0)
  48. {
  49. throw new LJCommonException("存在重复部门名称,请检查!");
  50. }
  51. // 初始化属性
  52. AutoInit.AutoInitS(cmd, request.dept);
  53. using (cmd.Transaction = con.BeginTransaction())
  54. {
  55. try
  56. {
  57. var dtNow = DateTime.Now;
  58. if (request.dept.deptid == null || request.dept.deptid <= 0)
  59. {
  60. //新建
  61. request.dept.createtime = dtNow;
  62. request.dept.deptid = BllHelper.GetID(cmd, "u_dept");
  63. var fields = "deptid,deptname,profitrate,pricelistid,springtypeid,createtime,moneyrate,discount,flag,if_rate_auto,manage_amt,mtrltype";
  64. DbSqlHelper.Insert(cmd, "u_dept", null, request.dept, fields);
  65. }
  66. else
  67. {
  68. //修改
  69. request.dept.moddate = dtNow;
  70. request.dept.modemp = tokendata.username;
  71. var fields = "deptname,profitrate,pricelistid,springtypeid,moneyrate,discount,flag,if_rate_auto,manage_amt,mtrltype,moddate,modemp";
  72. DbSqlHelper.Update(cmd, "u_dept", null, request.dept, "deptid", fields);
  73. }
  74. cmd.Transaction.Commit();
  75. }
  76. catch (Exception e)
  77. {
  78. cmd.Transaction.Rollback();
  79. rslt.ErrMsg = e.ToString();
  80. }
  81. }
  82. }
  83. }
  84. }
  85. }