SycnSpTradeServiceTest.cs 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using MySystem.PxcModels;
  5. using Library;
  6. using LitJson;
  7. using System.Threading;
  8. namespace MySystem
  9. {
  10. public class SycnSpTradeServiceTest
  11. {
  12. public readonly static SycnSpTradeServiceTest Instance = new SycnSpTradeServiceTest();
  13. private SycnSpTradeServiceTest()
  14. { }
  15. public void Start()
  16. {
  17. Thread th = new Thread(StartDo);
  18. th.IsBackground = true;
  19. th.Start();
  20. }
  21. public void StartDo()
  22. {
  23. int StartId = 26867679;
  24. bool op = true;
  25. while(op)
  26. {
  27. WebCMSEntities db = new WebCMSEntities();
  28. List<TradeRecord> trades = db.TradeRecord.Where(m => m.Id > StartId && m.Id <= 27650622 && m.MerHelpFlag == 0 && m.Version == 0).OrderBy(m => m.Id).Take(20).ToList();
  29. if(trades.Count > 0)
  30. {
  31. foreach (TradeRecord trade in trades)
  32. {
  33. PosMachinesTwo pos = db.PosMachinesTwo.FirstOrDefault(m => m.PosSn == trade.SnNo) ?? new PosMachinesTwo();
  34. ulong MerHelpFlag = 0;
  35. decimal DepositAmt = decimal.Parse(function.CheckNum(pos.SeoKeyword));
  36. if (pos.DownFeeFlag == 1)
  37. {
  38. if (pos.DownFee == 0.6M)
  39. {
  40. MerHelpFlag = 3;
  41. }
  42. else
  43. {
  44. MerHelpFlag = 2;
  45. }
  46. }
  47. else if (pos.IsFirst == 0)
  48. {
  49. if (pos.DownFee == 0.6M)
  50. {
  51. MerHelpFlag = 3;
  52. }
  53. else
  54. {
  55. MerHelpFlag = 2;
  56. }
  57. }
  58. else if (pos.IsFirst == 1 || pos.BrandId == 14)
  59. {
  60. string DayString = RedisDbconn.Instance.Get<string>("pobjrule:1:HelpPolicy:Days");
  61. int Days = int.Parse(DayString); //天数
  62. if (pos.BindingTime != null)
  63. {
  64. DateTime CheckTime = pos.BindingTime.Value.AddDays(Days);
  65. if(pos.BrandId == 7)
  66. {
  67. CheckTime = DateTime.Parse(pos.BindingTime.Value.AddDays(Days + 1).ToString("yyyy-MM-dd") + " 03:00:00");
  68. }
  69. if (CheckTime > trade.CreateDate)
  70. {
  71. MerHelpFlag = 1;
  72. }
  73. }
  74. }
  75. if((pos.BrandId == 12 || pos.BrandId == 13) && pos.UpFeeFlag == 1 && pos.DownFeeFlag == 0)
  76. {
  77. MerHelpFlag = 2;
  78. }
  79. if((pos.BrandId == 10 || pos.BrandId == 11) && trade.SeoDescription == "T015" && MerHelpFlag == 1)
  80. {
  81. MerHelpFlag = 0;
  82. }
  83. int Version = 0;
  84. if(MerHelpFlag == 2) Version = 1;
  85. if(MerHelpFlag == 3) Version = 2;
  86. TradeRecord edit = db.TradeRecord.FirstOrDefault(m => m.Id == trade.Id);
  87. if(edit != null)
  88. {
  89. MerHelpFlag = MerHelpFlag >= 2 ? 1 : MerHelpFlag;
  90. if(edit.MerHelpFlag != MerHelpFlag)
  91. {
  92. edit.MerHelpFlag = MerHelpFlag;
  93. function.WriteLog(trade.SnNo + ";MerHelpFlag:" + MerHelpFlag, "重置活动期标记");
  94. }
  95. if(edit.Version != Version)
  96. {
  97. edit.Version = Version;
  98. function.WriteLog(trade.SnNo + ";Version:" + Version, "重置活动期标记");
  99. }
  100. db.SaveChanges();
  101. }
  102. StartId = trade.Id;
  103. }
  104. }
  105. else
  106. {
  107. op = false;
  108. }
  109. db.Dispose();
  110. }
  111. function.WriteLog("end!!!!!", "重置活动期标记");
  112. }
  113. }
  114. }