ResetUserTradeService.cs 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data;
  4. using System.Linq;
  5. using System.Threading;
  6. using MySystem.Models;
  7. using Library;
  8. namespace MySystem
  9. {
  10. public class ResetUserTradeService
  11. {
  12. public readonly static ResetUserTradeService Instance = new ResetUserTradeService();
  13. private ResetUserTradeService()
  14. { }
  15. public void Start()
  16. {
  17. Thread th = new Thread(doSomething);
  18. th.IsBackground = true;
  19. th.Start();
  20. }
  21. public void doSomething()
  22. {
  23. while (true)
  24. {
  25. string content = RedisDbconn.Instance.RPop<string>("ResetUserTradeQueue");
  26. if (!string.IsNullOrEmpty(content))
  27. {
  28. try
  29. {
  30. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  31. WebCMSEntities db = new WebCMSEntities();
  32. string[] datalist = content.Split(new string[] { "#cut#" }, StringSplitOptions.None);
  33. int UserId = int.Parse(datalist[0]);
  34. DateTime sdate = DateTime.Parse(datalist[1]);
  35. DateTime edate = DateTime.Parse(datalist[2]);
  36. int BrandId = int.Parse(datalist[3]);
  37. function.WriteLog(DateTime.Now.ToString(), "重置创客交易额");
  38. List<string> uids = new List<string>();
  39. DataTable userDt = OtherMySqlConn.dtable("select Id,ParentNav from Users where Id=" + UserId);
  40. if (userDt.Rows.Count > 0)
  41. {
  42. while (sdate <= edate)
  43. {
  44. string date = sdate.ToString("yyyy-MM-dd");
  45. string TradeDate = date.Replace("-", "");
  46. string TradeMonth = TradeDate.Substring(0, 6);
  47. string start = date + " 00:00:00";
  48. string end = DateTime.Parse(date).AddDays(1).ToString("yyyy-MM-dd") + " 00:00:00";
  49. string startId = "0", endId = "9999999999";
  50. DataRow userDr = userDt.Rows[0];
  51. string ParentNav = userDr["ParentNav"].ToString();
  52. OtherMySqlConn.op("delete from UserTradeDaySummary where UserId=" + UserId + " and BrandId=" + BrandId + " and TradeMonth='" + TradeMonth + "' and TradeDate='" + TradeDate + "' and SeoTitle='self'");
  53. DataTable selfdt = OtherMySqlConn.dtable("select BrandId,BankCardType,QrPayFlag,sum(TradeAmount) from TradeRecord where Id>=" + startId + " and Id<=" + endId + " and CreateDate>='" + start + "' and CreateDate<'" + end + "' and UserId=" + UserId + " and BrandId=" + BrandId + " group by BrandId,BankCardType,QrPayFlag");
  54. foreach (DataRow selfDr in selfdt.Rows)
  55. {
  56. int BankCardType = int.Parse(selfDr["BankCardType"].ToString());
  57. int QrPayFlag = int.Parse(selfDr["QrPayFlag"].ToString());
  58. decimal TradeAmount = decimal.Parse(selfDr[3].ToString());
  59. UserTradeDaySummary selfStat = db.UserTradeDaySummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.BrandId == BrandId && m.QueryCount == QrPayFlag && m.SeoTitle == "self");
  60. if (selfStat == null)
  61. {
  62. selfStat = db.UserTradeDaySummary.Add(new UserTradeDaySummary()
  63. {
  64. UserId = UserId,
  65. TradeMonth = TradeMonth,
  66. TradeDate = TradeDate,
  67. BrandId = BrandId,
  68. QueryCount = QrPayFlag,
  69. SeoTitle = "self",
  70. }).Entity;
  71. db.SaveChanges();
  72. }
  73. if (BankCardType == 0)
  74. {
  75. selfStat.DirectDebitTradeAmt += TradeAmount;
  76. }
  77. else if (BankCardType != 0)
  78. {
  79. selfStat.DirectTradeAmt += TradeAmount;
  80. }
  81. db.SaveChanges();
  82. }
  83. if (!string.IsNullOrEmpty(ParentNav))
  84. {
  85. ParentNav += "," + UserId + ",";
  86. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  87. foreach (string NavUserIdString in ParentNavList)
  88. {
  89. if (!uids.Contains(NavUserIdString + start))
  90. {
  91. uids.Add(NavUserIdString + start);
  92. int NavUserId = int.Parse(NavUserIdString);
  93. OtherMySqlConn.op("delete from UserTradeDaySummary where UserId=" + NavUserId + " and BrandId=" + BrandId + " and TradeMonth='" + TradeMonth + "' and TradeDate='" + TradeDate + "' and SeoTitle='team'");
  94. DataTable teamDt = OtherMySqlConn.dtable("select BrandId,BankCardType,QrPayFlag,sum(TradeAmount) from TradeRecord where Id>=" + startId + " and Id<=" + endId + " and CreateDate>='" + start + "' and CreateDate<'" + end + "' and UserId in (select Id from Users where ParentNav like '%," + NavUserId + ",%' or Id=" + NavUserId + ") and BrandId=" + BrandId + " group by BrandId,BankCardType,QrPayFlag");
  95. foreach (DataRow teamDr in teamDt.Rows)
  96. {
  97. int BankCardType = int.Parse(teamDr["BankCardType"].ToString());
  98. int QrPayFlag = int.Parse(teamDr["QrPayFlag"].ToString());
  99. decimal TradeAmount = decimal.Parse(teamDr[3].ToString());
  100. UserTradeDaySummary teamStat = db.UserTradeDaySummary.FirstOrDefault(m => m.UserId == NavUserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.BrandId == BrandId && m.QueryCount == QrPayFlag && m.SeoTitle == "team");
  101. if (teamStat == null)
  102. {
  103. teamStat = db.UserTradeDaySummary.Add(new UserTradeDaySummary()
  104. {
  105. UserId = NavUserId,
  106. TradeMonth = TradeMonth,
  107. TradeDate = TradeDate,
  108. BrandId = BrandId,
  109. QueryCount = QrPayFlag,
  110. SeoTitle = "team",
  111. }).Entity;
  112. db.SaveChanges();
  113. }
  114. if (BankCardType == 0)
  115. {
  116. teamStat.NonDirectDebitTradeAmt += TradeAmount;
  117. }
  118. else if (BankCardType != 0)
  119. {
  120. teamStat.NonDirectTradeAmt += TradeAmount;
  121. }
  122. db.SaveChanges();
  123. }
  124. }
  125. }
  126. }
  127. sdate = sdate.AddDays(1);
  128. Thread.Sleep(200);
  129. }
  130. }
  131. db.Dispose();
  132. function.WriteLog(DateTime.Now.ToString() + "\r\n\r\n", "重置创客交易额");
  133. }
  134. catch (Exception ex)
  135. {
  136. function.WriteLog(DateTime.Now.ToString() + ":" + ex.ToString(), "重置创客交易额异常");
  137. }
  138. }
  139. else
  140. {
  141. Thread.Sleep(5000);
  142. }
  143. }
  144. }
  145. }
  146. }