StatHelpProfitService.cs 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. using System;
  2. using System.Collections.Generic;
  3. using Library;
  4. using LitJson;
  5. using System.Linq;
  6. using System.Data;
  7. using System.Threading;
  8. using MySystem.PxcModels;
  9. namespace MySystem
  10. {
  11. public class StatHelpProfitService
  12. {
  13. public readonly static StatHelpProfitService Instance = new StatHelpProfitService();
  14. private StatHelpProfitService()
  15. { }
  16. // 统计交易额V2
  17. public void StartEverDayV2()
  18. {
  19. Thread th = new Thread(StartEverDayV2Do);
  20. th.IsBackground = true;
  21. th.Start();
  22. }
  23. public void StartEverDayV2Do()
  24. {
  25. while (true)
  26. {
  27. if (DateTime.Now.Hour >= 3)
  28. {
  29. StatTradeAmountEverDayV2();
  30. }
  31. Thread.Sleep(30000);
  32. }
  33. }
  34. public void StatTradeAmountEverDayV2()
  35. {
  36. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  37. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时执行助利宝交易额日志");
  38. WebCMSEntities db = new WebCMSEntities();
  39. using (var tran = db.Database.BeginTransaction())
  40. {
  41. try
  42. {
  43. string startId = function.ReadInstance("/TradeRecord/Id3.txt");
  44. if (string.IsNullOrEmpty(startId))
  45. {
  46. startId = "2750000";
  47. }
  48. DataTable idsDt = OtherMySqlConn.dtable("select Id from TradeRecord where Id>=" + startId + " and CreateDate>='2022-09-05 00:00:00' and MerchantId in (select MerchantId from HelpProfitMerIds) and SeoTitle='HelpProfit' and QueryCount>0 and QueryCount<3 order by Id limit 50");
  49. if (idsDt.Rows.Count > 0)
  50. {
  51. string ids = "";
  52. foreach (DataRow idsDr in idsDt.Rows)
  53. {
  54. ids += idsDr["Id"].ToString() + ",";
  55. startId = idsDr["Id"].ToString();
  56. }
  57. DataTable selfDt = OtherMySqlConn.dtable("select MerchantId,DATE_FORMAT(CreateDate,'%Y%m%d'),sum(TradeAmount) from TradeRecord where Id in (" + ids.TrimEnd(',') + ") group by MerchantId,DATE_FORMAT(CreateDate,'%Y%m%d')");
  58. if (selfDt.Rows.Count > 0)
  59. {
  60. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "实时执行助利宝交易额日志");
  61. foreach (DataRow selfDr in selfDt.Rows)
  62. {
  63. int MerchantId = int.Parse(selfDr["MerchantId"].ToString());
  64. string TradeDate = selfDr[1].ToString();
  65. string TradeMonth = TradeDate.Substring(0, 6);
  66. decimal TradeAmount = decimal.Parse(selfDr[2].ToString());
  67. HelpProfitMerIds merIds = db.HelpProfitMerIds.FirstOrDefault(m => m.MerchantId == MerchantId) ?? new HelpProfitMerIds();
  68. bool Check = CheckAmount(db, MerchantId, merIds.UserId, TradeMonth);
  69. if (Check)
  70. {
  71. HelpProfitMerTradeSummay selfStat = db.HelpProfitMerTradeSummay.FirstOrDefault(m => m.MerchantId == MerchantId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate);
  72. if (selfStat == null)
  73. {
  74. selfStat = db.HelpProfitMerTradeSummay.Add(new HelpProfitMerTradeSummay()
  75. {
  76. TradeMonth = TradeMonth,
  77. TradeDate = TradeDate,
  78. MerchantId = MerchantId,
  79. }).Entity;
  80. db.SaveChanges();
  81. }
  82. decimal MoreAmount = TradeAmount * 0.01M;
  83. int random = function.get_Random(0, 10000);
  84. // if(MoreAmount > 1 && random < 5000)
  85. // {
  86. MoreAmount = decimal.Parse(function.CheckInt(MoreAmount.ToString().Split(".")[0]));
  87. // }
  88. selfStat.TradeAmount += TradeAmount + MoreAmount;
  89. }
  90. }
  91. OtherMySqlConn.op("update TradeRecord set QueryCount=3 where Id in (" + ids.TrimEnd(',') + ")");
  92. function.WritePage("/TradeRecord/", "Id3.txt", startId);
  93. }
  94. db.SaveChanges();
  95. }
  96. tran.Commit();
  97. }
  98. catch (Exception ex)
  99. {
  100. tran.Rollback();
  101. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时执行助利宝交易额异常");
  102. }
  103. }
  104. db.Dispose();
  105. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时执行助利宝交易额日志");
  106. }
  107. //计算商户交易额是否入账
  108. private bool CheckAmount(WebCMSEntities db, int MerchantId, int UserId, string TradeMonth)
  109. {
  110. int Month = 1;
  111. decimal SingleTradeAmount = 0; //当月单台交易额
  112. bool check = db.HelpProfitMerTradeSummay.Any(m => m.MerchantId == MerchantId);
  113. if (check)
  114. {
  115. SingleTradeAmount = db.HelpProfitMerTradeSummay.Where(m => m.MerchantId == MerchantId && m.TradeMonth == TradeMonth).Sum(m => m.TradeAmount);
  116. Month = db.HelpProfitMerTradeSummay.Select(m => new { m.MerchantId, m.TradeMonth }).Where(m => m.MerchantId == MerchantId && Convert.ToInt32(m.TradeMonth) <= Convert.ToInt32(TradeMonth)).ToList().Select(m => m.TradeMonth).Distinct().Count();
  117. }
  118. decimal MonthAmount1 = EveryMonthFixedVal()[Month]; //当月额度
  119. decimal MonthAmount2 = EveryMonthFixedVal()[Month + 1]; //上月额度
  120. decimal MonthAmount3 = EveryMonthFixedVal()[Month + 2]; //上上月额度
  121. decimal MaxTradeAmount = 10 * MonthAmount1 + 20 * MonthAmount2 + 10 * MonthAmount3; //当月最大交易总额
  122. decimal CheckAmount = 500000 < MaxTradeAmount * 0.3M ? 500000 : MaxTradeAmount * 0.3M;
  123. //当月单台交易额 <= 50万或当月最大交易总额的30%(取小值),则入账
  124. if (SingleTradeAmount < CheckAmount)
  125. {
  126. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  127. DataTable dt = OtherMySqlConn.dtable("SELECT SUM(TradeAmount) TradeAmount FROM HelpProfitMerTradeSummay WHERE MerchantId IN(SELECT MerchantId FROM HelpProfitMerIds WHERE UserId IN(SELECT Id from Users WHERE ParentNav like '%," + UserId + ",%' OR Id=" + UserId + ")) AND TradeMonth='" + TradeMonth + "'");
  128. if (dt.Rows.Count > 0)
  129. {
  130. CheckAmount = decimal.Parse(function.CheckNum(dt.Rows[0]["TradeAmount"].ToString())); //当月总交易额
  131. //当月总交易额不超过当月最大交易总额,则入账
  132. if (CheckAmount < MaxTradeAmount)
  133. {
  134. return true;
  135. }
  136. }
  137. }
  138. return false;
  139. }
  140. //商户24个月,每月固定额度
  141. private Dictionary<int, decimal> EveryMonthFixedVal()
  142. {
  143. Dictionary<int, decimal> obj = new Dictionary<int, decimal>();
  144. obj.Add(1, 7M);
  145. obj.Add(2, 6M);
  146. obj.Add(3, 5M);
  147. obj.Add(4, 4M);
  148. obj.Add(5, 3M);
  149. obj.Add(6, 3M);
  150. obj.Add(7, 2.7M);
  151. obj.Add(8, 2.5M);
  152. obj.Add(9, 2M);
  153. obj.Add(10, 1.7M);
  154. obj.Add(11, 1.4M);
  155. obj.Add(12, 1.4M);
  156. obj.Add(13, 1.3M);
  157. obj.Add(14, 1.2M);
  158. obj.Add(15, 1.2M);
  159. obj.Add(16, 1M);
  160. obj.Add(17, 0.8M);
  161. obj.Add(18, 0.7M);
  162. obj.Add(19, 0.6M);
  163. obj.Add(20, 0.5M);
  164. obj.Add(21, 0.4M);
  165. obj.Add(22, 0.3M);
  166. obj.Add(23, 0.2M);
  167. obj.Add(24, 0.1M);
  168. return obj;
  169. }
  170. }
  171. }