StoreStockChangeHelper.cs 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. using Library;
  2. using MySystem.Models;
  3. using System;
  4. using System.Linq;
  5. namespace MySystem
  6. {
  7. public class StoreStockChangeHelper
  8. {
  9. public readonly static StoreStockChangeHelper Instance = new StoreStockChangeHelper();
  10. private StoreStockChangeHelper()
  11. { }
  12. public string Start()
  13. {
  14. bool op = true;
  15. WebCMSEntities db = new WebCMSEntities();
  16. string result = "";
  17. int total = 0;
  18. while (op)
  19. {
  20. StoreStockChange PopData = new StoreStockChange();
  21. try
  22. {
  23. //获取apserver待同步的数据,执行入库
  24. PopData = RedisDbconn.Instance.RPop<StoreStockChange>("Pop:StoreStockChange");
  25. if (PopData != null)
  26. {
  27. // StoreStockChange checkExist = db.StoreStockChange.FirstOrDefault(m => m.Id == PopData.Id);
  28. // if (checkExist != null)
  29. // {
  30. // checkExist = PopData;
  31. // }
  32. // else
  33. // {
  34. db.StoreStockChange.Add(PopData);
  35. // }
  36. if (total >= 20)
  37. {
  38. total = 0;
  39. db.SaveChanges();
  40. }
  41. if (PopData.TransType == 11)
  42. {
  43. }
  44. if (string.IsNullOrEmpty(result)) result = "success";
  45. }
  46. else
  47. {
  48. db.SaveChanges();
  49. op = false;
  50. }
  51. }
  52. catch (Exception ex)
  53. {
  54. ErrorMsg msg = new ErrorMsg();
  55. msg.Obj = PopData;
  56. msg.Time = DateTime.Now;
  57. msg.ErrorContent = ex.ToString();
  58. LogHelper.Instance.WriteLog(Newtonsoft.Json.JsonConvert.SerializeObject(msg), "Pop:StoreStockChange:Error");
  59. result = "有异常,请查看Pop:StoreStockChange:Error队列";
  60. }
  61. }
  62. db.Dispose();
  63. return result;
  64. }
  65. }
  66. }