StatResetService2.cs 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398
  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.PxcModels2;
  9. namespace MySystem
  10. {
  11. public class StatResetService2
  12. {
  13. public readonly static StatResetService2 Instance = new StatResetService2();
  14. private StatResetService2()
  15. { }
  16. public void StartReset()
  17. {
  18. Thread th = new Thread(StartResetMerchantDo);
  19. th.IsBackground = true;
  20. th.Start();
  21. Thread thUser = new Thread(StartResetUserSelfDo);
  22. thUser.IsBackground = true;
  23. thUser.Start();
  24. Thread thUserTeam = new Thread(StartResetUserTeamDo);
  25. thUserTeam.IsBackground = true;
  26. thUserTeam.Start();
  27. Thread thSn = new Thread(StartResetSnDo);
  28. thSn.IsBackground = true;
  29. thSn.Start();
  30. }
  31. public void StartResetMerchantDo()
  32. {
  33. while (true)
  34. {
  35. string content = RedisDbconn.Instance.RPop<string>("ResetMerchantStatDataQueue2");
  36. if (!string.IsNullOrEmpty(content))
  37. {
  38. StatResetMerchantAmount(content);
  39. }
  40. Thread.Sleep(10000);
  41. }
  42. }
  43. public void StatResetMerchantAmount(string content)
  44. {
  45. JsonData jsonObj = JsonMapper.ToObject(content);
  46. string merchantId = jsonObj["MerchantId"].ToString();
  47. string startDate = jsonObj["StartDate"].ToString();
  48. string endDate = jsonObj["EndDate"].ToString();
  49. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "重置商户交易额日志");
  50. WebCMSEntities db = new WebCMSEntities();
  51. string conn = Library.ConfigurationManager.AppSettings["StatSqlConnStr2"].ToString();
  52. KxsMainModels.WebCMSEntities maindb = new KxsMainModels.WebCMSEntities();
  53. using (var tran = db.Database.BeginTransaction())
  54. {
  55. try
  56. {
  57. DataTable selfDt = CustomerSqlConn.dtable("select MerchantId,PayMode,IsAct,DATE_FORMAT(CreateDate,'%Y%m%d'),sum(PayMoney),count(Id),sum(MerchantActualAmount) from ConsumerOrders where MerchantId=" + merchantId + " and CreateDate>='" + startDate.Substring(0, 4) + "-" + startDate.Substring(4, 2) + "-" + startDate.Substring(6, 2) + " 00:00:00' and CreateDate<='" + endDate.Substring(0, 4) + "-" + endDate.Substring(4, 2) + "-" + endDate.Substring(6, 2) + " 23:59:59' group by MerchantId,PayMode,IsAct,DATE_FORMAT(CreateDate,'%Y%m%d')", AppConfig.Base.SqlConn2);
  58. if (selfDt.Rows.Count > 0)
  59. {
  60. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "重置商户交易额日志");
  61. var ResetDate = "";
  62. bool check = false; //重置统计表数据开关
  63. decimal NonActAmounts = 0;
  64. decimal ActAmounts = 0;
  65. decimal AliPayInFactAmounts = 0;
  66. decimal WeChatInfactAmounts = 0;
  67. int OderCounts = 0;
  68. decimal InFactAmounts = 0;
  69. decimal TradeAmounts = 0;
  70. foreach (DataRow selfDr in selfDt.Rows)
  71. {
  72. int MerchantId = int.Parse(selfDr["MerchantId"].ToString());
  73. int PayMode = int.Parse(selfDr["PayMode"].ToString());
  74. int IsAct = int.Parse(selfDr["IsAct"].ToString());
  75. string TradeDate = selfDr[3].ToString();
  76. decimal TradeAmount = decimal.Parse(selfDr[4].ToString());
  77. int TradeCount = int.Parse(selfDr[5].ToString());
  78. decimal ActualAmount = decimal.Parse(selfDr[6].ToString());
  79. string TradeMonth = TradeDate.Substring(0, 6);
  80. //商户交易额
  81. MerchantAmountSummay merchantStat = db.MerchantAmountSummay.FirstOrDefault(m => m.MerchantId == MerchantId && m.IsAct == IsAct && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.PayMode == PayMode);
  82. if (merchantStat == null)
  83. {
  84. merchantStat = db.MerchantAmountSummay.Add(new MerchantAmountSummay()
  85. {
  86. MerchantId = MerchantId,
  87. TradeMonth = TradeMonth,
  88. TradeDate = TradeDate,
  89. PayMode = PayMode,
  90. IsAct = IsAct,
  91. }).Entity;
  92. db.SaveChanges();
  93. }
  94. var LastDate = ResetDate; //上次重置时间
  95. if (ResetDate == "")
  96. {
  97. LastDate = TradeDate;
  98. }
  99. ResetDate = TradeDate; //覆盖重置时间
  100. if (LastDate == TradeDate)
  101. {
  102. OderCounts += TradeCount;
  103. TradeAmounts += TradeAmount;
  104. if (IsAct == 0) NonActAmounts += TradeAmount;
  105. if (IsAct == 1) ActAmounts += TradeAmount;
  106. if (PayMode == 1) AliPayInFactAmounts += ActualAmount;
  107. if (PayMode == 2) WeChatInfactAmounts += ActualAmount;
  108. if (IsAct == 1) InFactAmounts += TradeAmount;
  109. if (selfDt.Rows.Count == 1)
  110. {
  111. CustomerSqlConn.op("UPDATE MerchantTradeSummary" + LastDate + " SET NonActAmount=" + NonActAmounts + ",ActAmount=" + ActAmounts + ",AliPayInFactAmount=" + AliPayInFactAmounts + ",WeChatInfactAmount=" + WeChatInfactAmounts + ",OderCount=" + OderCounts + ",InFactAmount=" + InFactAmounts + ",TradeAmount=" + TradeAmounts + " WHERE MerchantId=" + MerchantId + "", conn);
  112. CustomerSqlConn.op("UPDATE MerchantTradeSummaryList" + TradeMonth + " NonActAmount=" + NonActAmounts + ",ActAmount=" + ActAmounts + ",AliPayInFactAmount=" + AliPayInFactAmounts + ",WeChatInfactAmount=" + WeChatInfactAmounts + ",OderCount=" + OderCounts + ",InFactAmount=" + InFactAmounts + ",TradeAmount=" + TradeAmounts + " WHERE MerchantId=" + MerchantId + " AND TradeDate='" + LastDate + "'", conn);
  113. }
  114. }
  115. else
  116. {
  117. check = true;
  118. if (check)
  119. {
  120. if (check)
  121. {
  122. CustomerSqlConn.op("UPDATE MerchantTradeSummary" + LastDate + " SET NonActAmount=" + NonActAmounts + ",ActAmount=" + ActAmounts + ",AliPayInFactAmount=" + AliPayInFactAmounts + ",WeChatInfactAmount=" + WeChatInfactAmounts + ",OderCount=" + OderCounts + ",InFactAmount=" + InFactAmounts + ",TradeAmount=" + TradeAmounts + " WHERE MerchantId=" + MerchantId + "", conn);
  123. CustomerSqlConn.op("UPDATE MerchantTradeSummaryList" + TradeMonth + " NonActAmount=" + NonActAmounts + ",ActAmount=" + ActAmounts + ",AliPayInFactAmount=" + AliPayInFactAmounts + ",WeChatInfactAmount=" + WeChatInfactAmounts + ",OderCount=" + OderCounts + ",InFactAmount=" + InFactAmounts + ",TradeAmount=" + TradeAmounts + " WHERE MerchantId=" + MerchantId + " AND TradeDate='" + LastDate + "'", conn);
  124. check = false;
  125. }
  126. }
  127. if (check == false)
  128. {
  129. OderCounts = TradeCount;
  130. TradeAmounts = TradeAmount;
  131. if (IsAct == 0) NonActAmounts = TradeAmount;
  132. if (IsAct == 1) ActAmounts = TradeAmount;
  133. if (PayMode == 1) AliPayInFactAmounts = ActualAmount;
  134. if (PayMode == 2) WeChatInfactAmounts = ActualAmount;
  135. if (IsAct == 1) InFactAmounts = TradeAmount;
  136. }
  137. }
  138. merchantStat.TradeAmount = TradeAmount;
  139. merchantStat.TradeCount = TradeCount;
  140. merchantStat.TotalActual = ActualAmount;
  141. db.SaveChanges();
  142. }
  143. }
  144. tran.Commit();
  145. }
  146. catch (Exception ex)
  147. {
  148. tran.Rollback();
  149. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "重置商户交易额异常");
  150. }
  151. }
  152. db.Dispose();
  153. maindb.Dispose();
  154. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "重置商户交易额日志");
  155. }
  156. public void StartResetSnDo()
  157. {
  158. while (true)
  159. {
  160. string content = RedisDbconn.Instance.RPop<string>("ResetSnStatDataQueue2");
  161. if (!string.IsNullOrEmpty(content))
  162. {
  163. StatResetSnAmount(content);
  164. }
  165. Thread.Sleep(10000);
  166. }
  167. }
  168. public void StatResetSnAmount(string content)
  169. {
  170. JsonData jsonObj = JsonMapper.ToObject(content);
  171. string snNo = jsonObj["SnNo"].ToString();
  172. string startDate = jsonObj["StartDate"].ToString();
  173. string endDate = jsonObj["EndDate"].ToString();
  174. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "重置码牌交易额日志");
  175. WebCMSEntities db = new WebCMSEntities();
  176. KxsMainModels.WebCMSEntities maindb = new KxsMainModels.WebCMSEntities();
  177. using (var tran = db.Database.BeginTransaction())
  178. {
  179. try
  180. {
  181. DataTable selfDt = CustomerSqlConn.dtable("select SnNo,PayMode,IsAct,DATE_FORMAT(CreateDate,'%Y%m%d'),sum(PayMoney),count(Id),sum(MerchantActualAmount) from ConsumerOrders where SnNo=" + snNo + " and CreateDate>='" + startDate.Substring(0, 4) + "-" + startDate.Substring(4, 2) + "-" + startDate.Substring(6, 2) + " 00:00:00' and CreateDate<='" + endDate.Substring(0, 4) + "-" + endDate.Substring(4, 2) + "-" + endDate.Substring(6, 2) + " 23:59:59' group by SnNo,PayMode,IsAct,DATE_FORMAT(CreateDate,'%Y%m%d')", AppConfig.Base.SqlConn2);
  182. if (selfDt.Rows.Count > 0)
  183. {
  184. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "重置码牌交易额日志");
  185. foreach (DataRow selfDr in selfDt.Rows)
  186. {
  187. int PayMode = int.Parse(selfDr["PayMode"].ToString());
  188. int IsAct = int.Parse(selfDr["IsAct"].ToString());
  189. string SnNo = selfDr["SnNo"].ToString();
  190. string TradeDate = selfDr[3].ToString();
  191. decimal TradeAmount = decimal.Parse(selfDr[4].ToString());
  192. int TradeCount = int.Parse(selfDr[5].ToString());
  193. decimal ActualAmount = decimal.Parse(selfDr[6].ToString());
  194. string TradeMonth = TradeDate.Substring(0, 6);
  195. //码牌交易额
  196. QrCodeAmountSummay qrcode = db.QrCodeAmountSummay.FirstOrDefault(m => m.SnNo == SnNo && m.IsAct == IsAct && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.PayMode == PayMode);
  197. if (qrcode == null)
  198. {
  199. qrcode = db.QrCodeAmountSummay.Add(new QrCodeAmountSummay()
  200. {
  201. SnNo = SnNo,
  202. TradeMonth = TradeMonth,
  203. TradeDate = TradeDate,
  204. PayMode = PayMode,
  205. IsAct = IsAct,
  206. }).Entity;
  207. db.SaveChanges();
  208. }
  209. qrcode.TradeAmount += TradeAmount;
  210. qrcode.TradeCount += TradeCount;
  211. qrcode.TotalActual += ActualAmount;
  212. db.SaveChanges();
  213. }
  214. }
  215. tran.Commit();
  216. }
  217. catch (Exception ex)
  218. {
  219. tran.Rollback();
  220. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "重置码牌交易额异常");
  221. }
  222. }
  223. db.Dispose();
  224. maindb.Dispose();
  225. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "重置码牌交易额日志");
  226. }
  227. public void StartResetUserSelfDo()
  228. {
  229. while (true)
  230. {
  231. string content = RedisDbconn.Instance.RPop<string>("ResetUserSelfStatDataQueue2");
  232. if (!string.IsNullOrEmpty(content))
  233. {
  234. StatResetUserSelfAmount(content);
  235. }
  236. Thread.Sleep(10000);
  237. }
  238. }
  239. public void StatResetUserSelfAmount(string content)
  240. {
  241. JsonData jsonObj = JsonMapper.ToObject(content);
  242. string userId = jsonObj["UserId"].ToString();
  243. string startDate = jsonObj["StartDate"].ToString();
  244. string endDate = jsonObj["EndDate"].ToString();
  245. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "重置创客个人交易额日志");
  246. WebCMSEntities db = new WebCMSEntities();
  247. KxsMainModels.WebCMSEntities maindb = new KxsMainModels.WebCMSEntities();
  248. using (var tran = db.Database.BeginTransaction())
  249. {
  250. try
  251. {
  252. DataTable selfDt = CustomerSqlConn.dtable("select UserId,PayMode,IsAct,DATE_FORMAT(CreateDate,'%Y%m%d'),sum(PayMoney),count(Id) from ConsumerOrders where UserId=" + userId + " and CreateDate>='" + startDate.Substring(0, 4) + "-" + startDate.Substring(4, 2) + "-" + startDate.Substring(6, 2) + " 00:00:00' and CreateDate<='" + endDate.Substring(0, 4) + "-" + endDate.Substring(4, 2) + "-" + endDate.Substring(6, 2) + " 23:59:59' group by UserId,PayMode,IsAct,DATE_FORMAT(CreateDate,'%Y%m%d')", AppConfig.Base.SqlConn2);
  253. if (selfDt.Rows.Count > 0)
  254. {
  255. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "重置创客个人交易额日志");
  256. foreach (DataRow selfDr in selfDt.Rows)
  257. {
  258. int UserId = int.Parse(selfDr["UserId"].ToString());
  259. KxsMainModels.Users user = maindb.Users.FirstOrDefault(m => m.Id == UserId) ?? new KxsMainModels.Users();
  260. int PayMode = int.Parse(selfDr["PayMode"].ToString());
  261. int IsAct = int.Parse(selfDr["IsAct"].ToString());
  262. string TradeDate = selfDr[3].ToString();
  263. decimal TradeAmount = decimal.Parse(selfDr[4].ToString());
  264. int TradeCount = int.Parse(selfDr[5].ToString());
  265. string TradeMonth = TradeDate.Substring(0, 6);
  266. //创客交易额
  267. UserAmountSummary selfStat = db.UserAmountSummary.FirstOrDefault(m => m.UserId == UserId && m.IsAct == IsAct && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.PayMode == PayMode && m.SeoTitle == "self");
  268. if (selfStat == null)
  269. {
  270. selfStat = db.UserAmountSummary.Add(new UserAmountSummary()
  271. {
  272. UserId = UserId,
  273. TradeMonth = TradeMonth,
  274. TradeDate = TradeDate,
  275. PayMode = PayMode,
  276. IsAct = IsAct,
  277. SeoTitle = "self",
  278. }).Entity;
  279. db.SaveChanges();
  280. }
  281. selfStat.TotalAmount = TradeAmount;
  282. selfStat.TradeCount = TradeCount;
  283. db.SaveChanges();
  284. string ParentNav = user.ParentNav + "," + userId + ",";
  285. if (!string.IsNullOrEmpty(ParentNav))
  286. {
  287. string[] ParentNavList = ParentNav.Replace(",,", ",").Trim(',').Split(',');
  288. foreach (string id in ParentNavList)
  289. {
  290. string reqdata = "{\"UserId\":\"" + id + "\",\"StartDate\":\"" + startDate + "\",\"EndDate\":\"" + endDate + "\"}";
  291. RedisDbconn.Instance.AddList("ResetUserTeamStatDataQueue2", reqdata);
  292. }
  293. }
  294. }
  295. }
  296. tran.Commit();
  297. }
  298. catch (Exception ex)
  299. {
  300. tran.Rollback();
  301. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "重置创客个人交易额异常");
  302. }
  303. }
  304. db.Dispose();
  305. maindb.Dispose();
  306. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "重置创客个人交易额日志");
  307. }
  308. public void StartResetUserTeamDo()
  309. {
  310. while (true)
  311. {
  312. string content = RedisDbconn.Instance.RPop<string>("ResetUserTeamStatDataQueue2");
  313. if (!string.IsNullOrEmpty(content))
  314. {
  315. StatResetUserTeamAmount(content);
  316. }
  317. Thread.Sleep(10000);
  318. }
  319. }
  320. public void StatResetUserTeamAmount(string content)
  321. {
  322. JsonData jsonObj = JsonMapper.ToObject(content);
  323. int userId = int.Parse(jsonObj["UserId"].ToString());
  324. string startDate = jsonObj["StartDate"].ToString();
  325. string endDate = jsonObj["EndDate"].ToString();
  326. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "重置团队创客交易额日志");
  327. WebCMSEntities db = new WebCMSEntities();
  328. KxsMainModels.WebCMSEntities maindb = new KxsMainModels.WebCMSEntities();
  329. using (var tran = db.Database.BeginTransaction())
  330. {
  331. try
  332. {
  333. string subUserId = "0";
  334. var subusers = maindb.Users.Select(m => new { m.Id, m.ParentUserId }).Where(m => m.ParentUserId == userId).ToList();
  335. foreach (var subuser in subusers)
  336. {
  337. subUserId += "," + subuser.Id;
  338. }
  339. DataTable selfDt = CustomerSqlConn.dtable("select PayMode,TotalAmount,TradeMonth,TradeDate,UserId,TradeCount,IsAct from UserAmountSummary where UserId in (" + subUserId + ") and TradeDate>='" + startDate + "' and TradeDate<='" + endDate + "' and SeoTitle='team'", AppConfig.Base.SqlConn2);
  340. if (selfDt.Rows.Count > 0)
  341. {
  342. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "重置团队创客交易额日志");
  343. foreach (DataRow selfDr in selfDt.Rows)
  344. {
  345. int UserId = int.Parse(selfDr["UserId"].ToString());
  346. int PayMode = int.Parse(selfDr["PayMode"].ToString());
  347. int IsAct = int.Parse(selfDr["IsAct"].ToString());
  348. string TradeDate = selfDr["TradeDate"].ToString();
  349. decimal TradeAmount = decimal.Parse(selfDr["TotalAmount"].ToString());
  350. int TradeCount = int.Parse(selfDr["TradeCount"].ToString());
  351. string TradeMonth = selfDr["TradeMonth"].ToString();
  352. //创客交易额
  353. UserAmountSummary teamStat = db.UserAmountSummary.FirstOrDefault(m => m.UserId == UserId && m.IsAct == IsAct && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.PayMode == PayMode && m.SeoTitle == "Team");
  354. if (teamStat == null)
  355. {
  356. teamStat = db.UserAmountSummary.Add(new UserAmountSummary()
  357. {
  358. UserId = UserId,
  359. TradeMonth = TradeMonth,
  360. TradeDate = TradeDate,
  361. PayMode = PayMode,
  362. IsAct = IsAct,
  363. SeoTitle = "self",
  364. }).Entity;
  365. db.SaveChanges();
  366. }
  367. teamStat.TotalAmount = TradeAmount;
  368. teamStat.TradeCount = TradeCount;
  369. db.SaveChanges();
  370. }
  371. }
  372. tran.Commit();
  373. }
  374. catch (Exception ex)
  375. {
  376. tran.Rollback();
  377. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "重置团队创客交易额异常");
  378. }
  379. }
  380. db.Dispose();
  381. maindb.Dispose();
  382. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "重置团队创客交易额日志");
  383. }
  384. }
  385. }