StatService.cs 73 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235
  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 StatService
  12. {
  13. public readonly static StatService Instance = new StatService();
  14. private StatService()
  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. StatBusinessService.Instance.StatTradeAmountEverDayV2();
  31. StatHelpProfitService.Instance.StatTradeAmountEverDayV2();
  32. }
  33. Thread.Sleep(30000);
  34. }
  35. }
  36. //补交易额
  37. public void StartOther()
  38. {
  39. Thread th = new Thread(StartOtherV2Do);
  40. th.IsBackground = true;
  41. th.Start();
  42. }
  43. public void StartOtherV2Do()
  44. {
  45. while (true)
  46. {
  47. string content = RedisDbconn.Instance.RPop<string>("AddTradeRecordByPosIdQueue");
  48. if(!string.IsNullOrEmpty(content))
  49. {
  50. function.WriteLog("content:" + content, "补录同步未激活交易额");
  51. int PosId = int.Parse(function.CheckInt(content));
  52. WebCMSEntities db = new WebCMSEntities();
  53. PosMachinesTwo pos = db.PosMachinesTwo.FirstOrDefault(m => m.Id == PosId && m.ActivationState == 1);
  54. if(pos != null)
  55. {
  56. function.WriteLog("1", "补录同步未激活交易额");
  57. var Trades = db.TradeRecord.Select(m => new { m.Id, m.SnNo, m.CreateDate, m.ActStatus, m.MerchantId, m.BrandId, m.TradeAmount }).Where(m => m.Id > 10228440 && m.SnNo == pos.PosSn && m.CreateDate <= pos.ActivationTime && m.ActStatus == 0).ToList();
  58. function.WriteLog("未激活记录数:" + Trades.Count, "补录同步未激活交易额");
  59. foreach(var Trade in Trades)
  60. {
  61. //补创客交易
  62. StatTradeAmountEverDayV2(Trade.Id);
  63. //补商户交易
  64. if(Trade.CreateDate.Value < DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd") + " 00:00:00"))
  65. {
  66. string StatDate = Trade.CreateDate.Value.ToString("yyyyMMdd");
  67. string StatMonth = StatDate.Substring(0, 6);
  68. PosMerchantTradeSummay stat = db.PosMerchantTradeSummay.FirstOrDefault(m => m.BrandId == Trade.BrandId && m.MerchantId == Trade.MerchantId && m.TradeMonth == StatMonth && m.TradeDate == StatDate);
  69. if(stat == null)
  70. {
  71. stat = db.PosMerchantTradeSummay.Add(new PosMerchantTradeSummay()
  72. {
  73. BrandId = Trade.BrandId,
  74. MerchantId = Trade.MerchantId,
  75. TradeMonth = StatMonth,
  76. TradeDate = StatDate,
  77. }).Entity;
  78. db.SaveChanges();
  79. }
  80. stat.TradeAmount += Trade.TradeAmount;
  81. db.SaveChanges();
  82. }
  83. //交易记录设置标记(已执行,激活标记为已激活)
  84. CustomerSqlConn.op("update TradeRecord set QueryCount=1,ActStatus=1 where Id=" + Trade.Id, AppConfig.Base.SqlConn);
  85. }
  86. }
  87. db.Dispose();
  88. Thread.Sleep(1000);
  89. }
  90. else
  91. {
  92. Thread.Sleep(60000);
  93. }
  94. }
  95. }
  96. public void StatTradeAmountEverDayV2(int Id = 0)
  97. {
  98. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  99. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时执行交易额V2日志");
  100. WebCMSEntities db = new WebCMSEntities();
  101. using (var tran = db.Database.BeginTransaction())
  102. {
  103. try
  104. {
  105. string startId = function.ReadInstance("/TradeRecord/Id.txt");
  106. if(string.IsNullOrEmpty(startId))
  107. {
  108. startId = "867041";
  109. }
  110. string sql = "select Id from TradeRecord where Id>=" + startId + " and QueryCount=0 and ActStatus=1 order by Id limit 50";
  111. if(Id > 0)
  112. {
  113. sql = "select Id from TradeRecord where Id=" + Id;
  114. }
  115. DataTable idsDt = OtherMySqlConn.dtable(sql);
  116. if(idsDt.Rows.Count > 0)
  117. {
  118. string ids = "";
  119. foreach (DataRow idsDr in idsDt.Rows)
  120. {
  121. ids += idsDr["Id"].ToString() + ",";
  122. if(Id == 0)
  123. {
  124. startId = idsDr["Id"].ToString();
  125. }
  126. }
  127. DataTable selfDt = OtherMySqlConn.dtable("select UserId,ParentNav,BrandId,BankCardType,QrPayFlag,MerHelpFlag,Version,CapFlag,VipFlag,PayType,DATE_FORMAT(CreateDate,'%Y%m%d'),sum(TradeAmount),count(Id),SnNo from TradeRecord where Id in (" + ids.TrimEnd(',') + ") group by UserId,ParentNav,BrandId,BankCardType,QrPayFlag,MerHelpFlag,Version,CapFlag,VipFlag,PayType,DATE_FORMAT(CreateDate,'%Y%m%d'),SnNo");
  128. if (selfDt.Rows.Count > 0)
  129. {
  130. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "实时执行交易额V2日志");
  131. foreach (DataRow selfDr in selfDt.Rows)
  132. {
  133. int UserId = int.Parse(selfDr["UserId"].ToString());
  134. string SnNo = selfDr["SnNo"].ToString();
  135. if(UserId == 0)
  136. {
  137. PosMachinesTwo pos = db.PosMachinesTwo.FirstOrDefault(m => m.PosSn == SnNo);
  138. if(pos != null)
  139. {
  140. UserId = pos.UserId;
  141. }
  142. }
  143. Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  144. string ParentNav = user.ParentNav; //selfDr["ParentNav"].ToString();
  145. int BrandId = int.Parse(selfDr["BrandId"].ToString());
  146. int BankCardType = int.Parse(selfDr["BankCardType"].ToString());
  147. int QrPayFlag = int.Parse(selfDr["QrPayFlag"].ToString());
  148. int MerHelpFlag = int.Parse(selfDr["MerHelpFlag"].ToString());
  149. int Version = int.Parse(selfDr["Version"].ToString());
  150. int CapFlag = int.Parse(selfDr["CapFlag"].ToString());
  151. int VipFlag = int.Parse(selfDr["VipFlag"].ToString());
  152. int PayType = int.Parse(selfDr["PayType"].ToString());
  153. string TradeDate = selfDr[10].ToString();
  154. decimal TradeAmount = decimal.Parse(selfDr[11].ToString());
  155. int TradeCount = int.Parse(selfDr[12].ToString());
  156. string TradeMonth = TradeDate.Substring(0, 6);
  157. TradeDaySummary selfStat = db.TradeDaySummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.BrandId == BrandId && m.QueryCount == QrPayFlag && m.VipFlag == VipFlag && m.PayType == PayType && m.SeoTitle == "self");
  158. if (selfStat == null)
  159. {
  160. selfStat = db.TradeDaySummary.Add(new TradeDaySummary()
  161. {
  162. UserId = UserId,
  163. TradeMonth = TradeMonth,
  164. TradeDate = TradeDate,
  165. BrandId = BrandId,
  166. QueryCount = QrPayFlag,
  167. VipFlag = VipFlag,
  168. PayType = PayType,
  169. SeoTitle = "self",
  170. }).Entity;
  171. db.SaveChanges();
  172. }
  173. if (BankCardType == 0)
  174. {
  175. if (Version == 1)
  176. {
  177. selfStat.ProfitDirectDebitTradeAmt += TradeAmount;
  178. if (CapFlag == 1)
  179. {
  180. selfStat.ProfitDirectDebitCapTradeAmt += TradeAmount;
  181. selfStat.ProfitDirectDebitCapNum += TradeCount;
  182. }
  183. }
  184. else if (MerHelpFlag == 1)
  185. {
  186. selfStat.HelpDirectDebitTradeAmt += TradeAmount;
  187. if (CapFlag == 1)
  188. {
  189. selfStat.HelpDirectDebitCapTradeAmt += TradeAmount;
  190. selfStat.HelpDirectDebitCapNum += TradeCount;
  191. }
  192. }
  193. else
  194. {
  195. selfStat.NotHelpDirectDebitTradeAmt += TradeAmount;
  196. if (CapFlag == 1)
  197. {
  198. selfStat.NotHelpDirectDebitCapTradeAmt += TradeAmount;
  199. selfStat.NotHelpDirectDebitCapNum += TradeCount;
  200. }
  201. }
  202. }
  203. else if (BankCardType != 0)
  204. {
  205. if (Version == 1)
  206. {
  207. selfStat.ProfitDirectTradeAmt += TradeAmount;
  208. }
  209. else if (MerHelpFlag == 1)
  210. {
  211. selfStat.HelpDirectTradeAmt += TradeAmount;
  212. }
  213. else
  214. {
  215. selfStat.NotHelpDirectTradeAmt += TradeAmount;
  216. }
  217. }
  218. ParentNav += "," + UserId + ",";
  219. if (!string.IsNullOrEmpty(ParentNav))
  220. {
  221. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  222. foreach (string NavUserIdString in ParentNavList)
  223. {
  224. int NavUserId = int.Parse(NavUserIdString);
  225. TradeDaySummary teamStat = db.TradeDaySummary.FirstOrDefault(m => m.UserId == NavUserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.BrandId == BrandId && m.QueryCount == QrPayFlag && m.VipFlag == VipFlag && m.PayType == PayType && m.SeoTitle == "team");
  226. if (teamStat == null)
  227. {
  228. teamStat = db.TradeDaySummary.Add(new TradeDaySummary()
  229. {
  230. UserId = NavUserId,
  231. TradeMonth = TradeMonth,
  232. TradeDate = TradeDate,
  233. BrandId = BrandId,
  234. QueryCount = QrPayFlag,
  235. VipFlag = VipFlag,
  236. PayType = PayType,
  237. SeoTitle = "team",
  238. }).Entity;
  239. db.SaveChanges();
  240. }
  241. if (BankCardType == 0)
  242. {
  243. if (Version == 1)
  244. {
  245. teamStat.ProfitNonDirectDebitTradeAmt += TradeAmount;
  246. if (CapFlag == 1)
  247. {
  248. teamStat.ProfitDirectDebitCapTradeAmt += TradeAmount;
  249. teamStat.ProfitDirectDebitCapNum += TradeCount;
  250. }
  251. }
  252. else if (MerHelpFlag == 1)
  253. {
  254. teamStat.HelpNonDirectDebitTradeAmt += TradeAmount;
  255. if (CapFlag == 1)
  256. {
  257. teamStat.HelpDirectDebitCapTradeAmt += TradeAmount;
  258. teamStat.HelpDirectDebitCapNum += TradeCount;
  259. }
  260. }
  261. else
  262. {
  263. teamStat.NotHelpNonDirectDebitTradeAmt += TradeAmount;
  264. if (CapFlag == 1)
  265. {
  266. teamStat.NotHelpDirectDebitCapTradeAmt += TradeAmount;
  267. teamStat.NotHelpDirectDebitCapNum += TradeCount;
  268. }
  269. }
  270. }
  271. else if (BankCardType != 0)
  272. {
  273. if (Version == 1)
  274. {
  275. teamStat.ProfitNonDirectTradeAmt += TradeAmount;
  276. }
  277. else if (MerHelpFlag == 1)
  278. {
  279. teamStat.HelpNonDirectTradeAmt += TradeAmount;
  280. }
  281. else
  282. {
  283. teamStat.NotHelpNonDirectTradeAmt += TradeAmount;
  284. }
  285. }
  286. }
  287. }
  288. Dictionary<string, object> statData = new Dictionary<string, object>();
  289. statData.Add("UserId", UserId);
  290. statData.Add("BrandId", BrandId);
  291. statData.Add("BankCardType", BankCardType);
  292. statData.Add("QrPayFlag", QrPayFlag);
  293. statData.Add("MerHelpFlag", MerHelpFlag);
  294. statData.Add("Version", Version);
  295. statData.Add("CapFlag", CapFlag);
  296. statData.Add("VipFlag", VipFlag);
  297. statData.Add("PayType", PayType);
  298. statData.Add("TradeDate", TradeDate);
  299. statData.Add("TradeAmount", TradeAmount);
  300. statData.Add("TradeCount", TradeCount);
  301. RedisDbconn.Instance.AddList("StatTradeAmountQueue", Newtonsoft.Json.JsonConvert.SerializeObject(statData));
  302. RedisDbconn.Instance.AddList("ProfitTradeAmountQueue", Newtonsoft.Json.JsonConvert.SerializeObject(statData));
  303. }
  304. OtherMySqlConn.op("update TradeRecord set QueryCount=1 where Id in (" + ids.TrimEnd(',') + ")");
  305. if(Id == 0)
  306. {
  307. function.WritePage("/TradeRecord/", "Id.txt", startId);
  308. }
  309. }
  310. db.SaveChanges();
  311. }
  312. tran.Commit();
  313. }
  314. catch (Exception ex)
  315. {
  316. tran.Rollback();
  317. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "统计昨天交易额V2异常");
  318. }
  319. }
  320. db.Dispose();
  321. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时执行交易额V2日志");
  322. }
  323. // 每天统计头一天的交易额
  324. public void StartEverDay(string date)
  325. {
  326. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  327. // DateTime end = DateTime.Parse("2022-04-19 00:00:00");
  328. // DateTime check = DateTime.Parse("2022-03-11");
  329. // while (check <= end)
  330. // {
  331. // Thread th = new Thread(StatTradeAmountEverDay);
  332. // th.IsBackground = true;
  333. // th.Start(check.ToString("yyyy-MM-dd"));
  334. // check = check.AddDays(1);
  335. // }
  336. if (DateTime.Now.Day == 2)
  337. {
  338. OtherMySqlConn.op("update Users set ThisMonthTrade=0 where ThisMonthTrade>0");
  339. DataTable list = OtherMySqlConn.dtable("select UserId,sum(NonDirectTradeAmt) from UserTradeDaySummary where TradeMonth='" + DateTime.Now.ToString("yyyyMM") + "' GROUP BY UserId");
  340. foreach (DataRow dr in list.Rows)
  341. {
  342. string UserId = dr["UserId"].ToString();
  343. string ThisMonthTrade = dr[1].ToString();
  344. OtherMySqlConn.op("update Users set ThisMonthTrade=" + ThisMonthTrade + " where Id=" + UserId);
  345. }
  346. }
  347. Thread th = new Thread(StatTradeAmountEverDay);
  348. th.IsBackground = true;
  349. th.Start(date);
  350. }
  351. public void StatTradeAmountEverDay(object sender)
  352. {
  353. string date = sender.ToString();
  354. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "执行昨天交易额日志");
  355. WebCMSEntities db = new WebCMSEntities();
  356. try
  357. {
  358. string TradeDate = date.Replace("-", "");
  359. string TradeMonth = TradeDate.Substring(0, 6);
  360. string start = date + " 00:00:00";
  361. string end = DateTime.Parse(date).AddDays(1).ToString("yyyy-MM-dd") + " 00:00:00";
  362. string startId = "0", endId = "9999999999";
  363. List<string> uids = new List<string>();
  364. DataTable startDt = OtherMySqlConn.dtable("select min(Id) from TradeRecord where CreateDate>='" + start + "'");
  365. if (startDt.Rows.Count > 0)
  366. {
  367. startId = startDt.Rows[0][0].ToString();
  368. }
  369. function.WriteLog(startId + "\n\n", "执行昨天交易额日志");
  370. // DataTable endDt = OtherMySqlConn.dtable("select max(Id) from TradeRecord where CreateDate<'" + end + "'");
  371. // if (endDt.Rows.Count > 0)
  372. // {
  373. // endId = endDt.Rows[0][0].ToString();
  374. // }
  375. DataTable userDt = OtherMySqlConn.dtable("select Id,ParentNav from Users where Id in (select DISTINCT UserId from TradeRecord where Id>=" + startId + " and Id<=" + endId + " and CreateDate>='" + start + "' and CreateDate<'" + end + "')");
  376. function.WriteLog("交易人数:" + userDt.Rows.Count + "\n\n", "执行昨天交易额日志");
  377. foreach (DataRow userDr in userDt.Rows)
  378. {
  379. int UserId = int.Parse(userDr["Id"].ToString());
  380. string ParentNav = userDr["ParentNav"].ToString();
  381. function.WriteLog(UserId + ":" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行昨天交易额日志");
  382. 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 + " group by BrandId,BankCardType,QrPayFlag");
  383. function.WriteLog(UserId + ":" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行昨天交易额日志");
  384. foreach (DataRow selfDr in selfdt.Rows)
  385. {
  386. int BrandId = int.Parse(selfDr["BrandId"].ToString());
  387. int BankCardType = int.Parse(selfDr["BankCardType"].ToString());
  388. int QrPayFlag = int.Parse(selfDr["QrPayFlag"].ToString());
  389. decimal TradeAmount = decimal.Parse(selfDr[3].ToString());
  390. UserTradeDaySummary selfStat = db.UserTradeDaySummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.BrandId == BrandId && m.QueryCount == QrPayFlag && m.SeoTitle == "self");
  391. if (selfStat == null)
  392. {
  393. selfStat = db.UserTradeDaySummary.Add(new UserTradeDaySummary()
  394. {
  395. UserId = UserId,
  396. TradeMonth = TradeMonth,
  397. TradeDate = TradeDate,
  398. BrandId = BrandId,
  399. QueryCount = QrPayFlag,
  400. SeoTitle = "self",
  401. }).Entity;
  402. db.SaveChanges();
  403. }
  404. if (BankCardType == 0)
  405. {
  406. selfStat.DirectDebitTradeAmt += TradeAmount;
  407. }
  408. else if (BankCardType != 0)
  409. {
  410. selfStat.DirectTradeAmt += TradeAmount;
  411. }
  412. db.SaveChanges();
  413. }
  414. if (!string.IsNullOrEmpty(ParentNav))
  415. {
  416. ParentNav += "," + UserId + ",";
  417. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  418. foreach (string NavUserIdString in ParentNavList)
  419. {
  420. if (!uids.Contains(NavUserIdString + start))
  421. {
  422. uids.Add(NavUserIdString + start);
  423. int NavUserId = int.Parse(NavUserIdString);
  424. function.WriteLog(NavUserId + ":team:" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行昨天交易额日志");
  425. 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 + ") group by BrandId,BankCardType,QrPayFlag");
  426. function.WriteLog(NavUserId + ":team:" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行昨天交易额日志");
  427. foreach (DataRow teamDr in teamDt.Rows)
  428. {
  429. int BrandId = int.Parse(teamDr["BrandId"].ToString());
  430. int BankCardType = int.Parse(teamDr["BankCardType"].ToString());
  431. int QrPayFlag = int.Parse(teamDr["QrPayFlag"].ToString());
  432. decimal TradeAmount = decimal.Parse(teamDr[3].ToString());
  433. UserTradeDaySummary teamStat = db.UserTradeDaySummary.FirstOrDefault(m => m.UserId == NavUserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.BrandId == BrandId && m.QueryCount == QrPayFlag && m.SeoTitle == "team");
  434. if (teamStat == null)
  435. {
  436. teamStat = db.UserTradeDaySummary.Add(new UserTradeDaySummary()
  437. {
  438. UserId = NavUserId,
  439. TradeMonth = TradeMonth,
  440. TradeDate = TradeDate,
  441. BrandId = BrandId,
  442. QueryCount = QrPayFlag,
  443. SeoTitle = "team",
  444. }).Entity;
  445. db.SaveChanges();
  446. }
  447. if (BankCardType == 0)
  448. {
  449. teamStat.NonDirectDebitTradeAmt += TradeAmount;
  450. }
  451. else if (BankCardType != 0)
  452. {
  453. teamStat.NonDirectTradeAmt += TradeAmount;
  454. }
  455. db.SaveChanges();
  456. }
  457. }
  458. }
  459. }
  460. }
  461. if (DateTime.Now.Day >= 2)
  462. {
  463. Thread.Sleep(5000);
  464. DataTable list = OtherMySqlConn.dtable("select UserId,sum(NonDirectTradeAmt) from UserTradeDaySummary where TradeDate='" + TradeDate + "' GROUP BY UserId");
  465. foreach (DataRow dr in list.Rows)
  466. {
  467. string UserId = dr["UserId"].ToString();
  468. string ThisMonthTrade = dr[1].ToString();
  469. OtherMySqlConn.op("update Users set ThisMonthTrade=ThisMonthTrade+" + ThisMonthTrade + " where Id=" + UserId);
  470. }
  471. }
  472. }
  473. catch (Exception ex)
  474. {
  475. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "统计昨天的交易额异常");
  476. }
  477. db.Dispose();
  478. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行昨天交易额日志");
  479. StatMerchantTrade(date);
  480. }
  481. public void StatTradeAmountEverDaySum()
  482. {
  483. // WebCMSEntities db = new WebCMSEntities();
  484. // OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  485. // DataTable dt = OtherMySqlConn.dtable("select UserId,BrandId,QueryCount,TradeDate,TradeMonth,sum(DirectDebitTradeAmt) as DirectDebitTradeAmt,sum(DirectTradeAmt) as DirectTradeAmt,sum(NonDirectDebitTradeAmt) as NonDirectDebitTradeAmt,sum(NonDirectTradeAmt) as NonDirectTradeAmt from UserTradeDaySummary group by UserId,BrandId,QueryCount,TradeDate,TradeMonth order by UserId,BrandId,QueryCount");
  486. // string html = "<table>";
  487. // foreach (DataRow dr in dt.Rows)
  488. // {
  489. // html += "<tr>";
  490. // string TradeDate = dr["TradeDate"].ToString();
  491. // string TradeMonth = dr["TradeMonth"].ToString();
  492. // int UserId = int.Parse(dr["UserId"].ToString());
  493. // int BrandId = int.Parse(dr["BrandId"].ToString());
  494. // int QrPayFlag = int.Parse(dr["QueryCount"].ToString());
  495. // decimal DirectDebitTradeAmt = decimal.Parse(dr["DirectDebitTradeAmt"].ToString());
  496. // decimal DirectTradeAmt = decimal.Parse(dr["DirectTradeAmt"].ToString());
  497. // decimal NonDirectDebitTradeAmt = decimal.Parse(dr["NonDirectDebitTradeAmt"].ToString());
  498. // decimal NonDirectTradeAmt = decimal.Parse(dr["NonDirectTradeAmt"].ToString());
  499. // decimal CurAmount = 0, CurTotalAmount = 0, CurMonthAmount = 0, CurDayAmount = 0;
  500. // CurTotalAmount = RedisDbconn.Instance.Get<decimal>("TotalAmount:" + UserId); //总交易
  501. // CurMonthAmount = RedisDbconn.Instance.Get<decimal>("TotalAmount:" + UserId + ":" + TradeDate); //总交易
  502. // CurDayAmount = RedisDbconn.Instance.Get<decimal>("TotalAmount:" + UserId + ":" + TradeMonth); //总交易
  503. // CurAmount = RedisDbconn.Instance.Get<decimal>("TotalAmount:" + UserId + ":" + BrandId + ":" + TradeDate); //总交易
  504. // decimal TotalPosAmount = 0;
  505. // decimal TotalCloudPayAmount = 0;
  506. // decimal TeamTotalPosAmount = 0;
  507. // decimal TeamTotalCloudPayAmount = 0;
  508. // if (QrPayFlag == 1)
  509. // {
  510. // TotalCloudPayAmount = RedisDbconn.Instance.Get<decimal>("TotalCloudPayAmount:" + UserId + ":" + TradeDate); //云闪付小额交易额
  511. // TeamTotalCloudPayAmount = RedisDbconn.Instance.Get<decimal>("TeamTotalCloudPayAmount:" + UserId + ":" + TradeDate); //POS机刷卡交易额
  512. // }
  513. // else
  514. // {
  515. // TotalPosAmount = RedisDbconn.Instance.Get<decimal>("TotalPosAmount:" + UserId + ":" + TradeDate); //POS机刷卡交易额
  516. // TeamTotalPosAmount = RedisDbconn.Instance.Get<decimal>("TeamTotalPosAmount:" + UserId + ":" + TradeDate); //云闪付小额交易额
  517. // }
  518. // Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  519. // html += "<td>应得</td>";
  520. // html += "<td>" + user.MakerCode + "</td>";
  521. // html += "<td>" + user.RealName + "</td>";
  522. // html += "<td>" + user.Mobile + "</td>";
  523. // html += "<td>" + BrandId + "</td>";
  524. // html += "<td>" + QrPayFlag + "</td>";
  525. // html += "<td>" + DirectDebitTradeAmt + "</td>";
  526. // html += "<td>" + DirectTradeAmt + "</td>";
  527. // html += "<td>" + NonDirectDebitTradeAmt + "</td>";
  528. // html += "<td>" + NonDirectTradeAmt + "</td>";
  529. // html += "</tr>";
  530. // html += "<tr>";
  531. // html += "<td>当前</td>";
  532. // html += "<td></td>";
  533. // html += "<td></td>";
  534. // html += "<td>当天品牌:" + CurAmount + "</td>";
  535. // html += "<td>总交易:" + CurTotalAmount + "</td>";
  536. // html += "<td>当月:" + CurMonthAmount + "</td>";
  537. // html += "<td>当天:" + CurDayAmount + "</td>";
  538. // html += "<td>" + TotalPosAmount + "</td>";
  539. // html += "<td>" + TotalCloudPayAmount + "</td>";
  540. // html += "<td>" + TeamTotalPosAmount + "</td>";
  541. // html += "<td>" + TeamTotalCloudPayAmount + "</td>";
  542. // html += "</tr>";
  543. // }
  544. // html += "</table>";
  545. // db.Dispose();
  546. // // OtherMySqlConn.connstr = ;
  547. // function.WritePage("/html/", "1.html", html);
  548. }
  549. //统计商户交易额
  550. private void StatMerchantTrade(string date)
  551. {
  552. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "执行商户交易额日志");
  553. // WebCMSEntities db = new WebCMSEntities();
  554. try
  555. {
  556. string start = date + " 00:00:00";
  557. string end = DateTime.Parse(date).AddDays(1).ToString("yyyy-MM-dd") + " 00:00:00";
  558. OtherMySqlConn.op("insert into PosMerchantTradeSummay (MerchantId,BrandId,TradeDate,TradeMonth,TradeAmount,CreateDate) select *,now() from (select MerchantId,BrandId,DATE_FORMAT(CreateDate,'%Y%m%d') as TradeDate,DATE_FORMAT(CreateDate,'%Y%m') as TradeMonth,sum(TradeAmount) as TradeAmount from TradeRecord where CreateDate>='" + start + "' and CreateDate<'" + end + "' group by MerchantId,BrandId,DATE_FORMAT(CreateDate,'%Y%m%d'),TradeDate,DATE_FORMAT(CreateDate,'%Y%m') order by MerchantId,BrandId,DATE_FORMAT(CreateDate,'%Y%m%d')) tb");
  559. }
  560. catch (Exception ex)
  561. {
  562. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "统计商户的交易额");
  563. }
  564. // db.Dispose();
  565. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行商户交易额日志");
  566. }
  567. // 统计创客激活数
  568. public void StartPosActNum()
  569. {
  570. Thread th = new Thread(StartPosActNumFor);
  571. th.IsBackground = true;
  572. th.Start();
  573. }
  574. public void StartPosActNumFor()
  575. {
  576. // DateTime end = DateTime.Parse("2022-06-15 00:00:00");
  577. // DateTime check = DateTime.Parse("2022-06-14");
  578. // while (check <= end)
  579. // {
  580. // StartPosActNumDo(check.ToString("yyyy-MM-dd"));
  581. // check = check.AddDays(1);
  582. // }
  583. while (true)
  584. {
  585. if(DateTime.Now.Hour >= 3)
  586. {
  587. StartPosActNumEverTime();
  588. StatBusinessService.Instance.StartPosActNumEverTime();
  589. }
  590. Thread.Sleep(120000);
  591. }
  592. }
  593. public void StartPosActNumDo(object sender)
  594. {
  595. string date = sender.ToString();
  596. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "执行创客激活数日志");
  597. WebCMSEntities db = new WebCMSEntities();
  598. try
  599. {
  600. string TradeDate = date.Replace("-", "");
  601. string TradeMonth = TradeDate.Substring(0, 6);
  602. string start = date + " 00:00:00";
  603. string end = DateTime.Parse(date).AddDays(1).ToString("yyyy-MM-dd") + " 00:00:00";
  604. List<string> uids = new List<string>();
  605. DataTable userDt = OtherMySqlConn.dtable("select Id,ParentNav from Users where Id in (select DISTINCT BuyUserId from PosMachinesTwo where QueryCount=0 and ActivationState=1 and ActivationTime>='" + start + "' and ActivationTime<'" + end + "')");
  606. function.WriteLog("人数:" + userDt.Rows.Count + "\n\n", "执行创客激活数日志");
  607. foreach (DataRow userDr in userDt.Rows)
  608. {
  609. int UserId = int.Parse(userDr["Id"].ToString());
  610. string ParentNav = userDr["ParentNav"].ToString();
  611. function.WriteLog(UserId + ":" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行创客激活数日志");
  612. DataTable selfdt = OtherMySqlConn.dtable("select BrandId,count(Id) from PosMachinesTwo where QueryCount=0 and ActivationState=1 and ActivationTime>='" + start + "' and ActivationTime<'" + end + "' and BuyUserId=" + UserId + " group by BrandId");
  613. function.WriteLog(UserId + ":" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行创客激活数日志");
  614. foreach (DataRow selfDr in selfdt.Rows)
  615. {
  616. int BrandId = int.Parse(selfDr["BrandId"].ToString());
  617. int QrPayFlag = 0;
  618. int ActCount = int.Parse(selfDr[1].ToString());
  619. UserTradeDaySummary selfStat = db.UserTradeDaySummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.BrandId == BrandId && m.QueryCount == QrPayFlag && m.SeoTitle == "self");
  620. if (selfStat == null)
  621. {
  622. selfStat = db.UserTradeDaySummary.Add(new UserTradeDaySummary()
  623. {
  624. UserId = UserId,
  625. TradeMonth = TradeMonth,
  626. TradeDate = TradeDate,
  627. BrandId = BrandId,
  628. QueryCount = QrPayFlag,
  629. SeoTitle = "self",
  630. }).Entity;
  631. db.SaveChanges();
  632. }
  633. selfStat.DirectDebitCapNum += ActCount;
  634. db.SaveChanges();
  635. }
  636. if (!string.IsNullOrEmpty(ParentNav))
  637. {
  638. ParentNav += "," + UserId + ",";
  639. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  640. foreach (string NavUserIdString in ParentNavList)
  641. {
  642. if (!uids.Contains(NavUserIdString + start))
  643. {
  644. uids.Add(NavUserIdString + start);
  645. int NavUserId = int.Parse(NavUserIdString);
  646. function.WriteLog(NavUserId + ":team:" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行创客激活数日志");
  647. DataTable teamDt = OtherMySqlConn.dtable("select BrandId,count(Id) from PosMachinesTwo where QueryCount=0 and ActivationState=1 and ActivationTime>='" + start + "' and ActivationTime<'" + end + "' and BuyUserId in (select Id from Users where ParentNav like '%," + NavUserId + ",%' or Id=" + NavUserId + ") group by BrandId");
  648. function.WriteLog(NavUserId + ":team:" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行创客激活数日志");
  649. foreach (DataRow teamDr in teamDt.Rows)
  650. {
  651. int BrandId = int.Parse(teamDr["BrandId"].ToString());
  652. int QrPayFlag = 0;
  653. int ActCount = int.Parse(teamDr[1].ToString());
  654. UserTradeDaySummary teamStat = db.UserTradeDaySummary.FirstOrDefault(m => m.UserId == NavUserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.BrandId == BrandId && m.QueryCount == QrPayFlag && m.SeoTitle == "team");
  655. if (teamStat == null)
  656. {
  657. teamStat = db.UserTradeDaySummary.Add(new UserTradeDaySummary()
  658. {
  659. UserId = NavUserId,
  660. TradeMonth = TradeMonth,
  661. TradeDate = TradeDate,
  662. BrandId = BrandId,
  663. QueryCount = QrPayFlag,
  664. SeoTitle = "team",
  665. }).Entity;
  666. db.SaveChanges();
  667. }
  668. teamStat.NonDirectDebitCapNum += ActCount;
  669. db.SaveChanges();
  670. }
  671. }
  672. }
  673. }
  674. }
  675. OtherMySqlConn.op("update PosMachinesTwo set QueryCount=1 where QueryCount=0 and ActivationState=1 and ActivationTime>='" + start + "' and ActivationTime<'" + end + "'");
  676. }
  677. catch (Exception ex)
  678. {
  679. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "执行创客激活数异常");
  680. }
  681. db.Dispose();
  682. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行创客激活数日志");
  683. Thread.Sleep(60000);
  684. }
  685. public void StartPosActNumEverTime()
  686. {
  687. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  688. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时执行创客激活数日志");
  689. WebCMSEntities db = new WebCMSEntities();
  690. try
  691. {
  692. DataTable idsDt = OtherMySqlConn.dtable("select Id from PosMachinesTwo where QueryCount=0 and ActivationState=1 and ActivationTime is not null and ActivationTime>='2022-06-01 00:00:00' and BuyUserId>0 limit 50");
  693. if(idsDt.Rows.Count > 0)
  694. {
  695. string ids = "";
  696. foreach (DataRow idsDr in idsDt.Rows)
  697. {
  698. ids += idsDr["Id"].ToString() + ",";
  699. }
  700. DataTable userDt = OtherMySqlConn.dtable("select BuyUserId,StoreId,BrandId,DATE_FORMAT(ActivationTime, '%Y%m%d'),count(Id) from PosMachinesTwo where Id in (" + ids.TrimEnd(',') + ") group by BuyUserId,StoreId,BrandId,DATE_FORMAT(ActivationTime, '%Y%m%d')");
  701. if (userDt.Rows.Count > 0)
  702. {
  703. function.WriteLog("人数:" + userDt.Rows.Count + "\n\n", "实时执行创客激活数日志");
  704. foreach (DataRow userDr in userDt.Rows)
  705. {
  706. int UserId = int.Parse(userDr["BuyUserId"].ToString());
  707. int StoreId = int.Parse(userDr["StoreId"].ToString());
  708. int BrandId = int.Parse(userDr["BrandId"].ToString());
  709. string TradeDate = userDr[3].ToString();
  710. int ActCount = int.Parse(function.CheckInt(userDr[4].ToString()));
  711. int QrPayFlag = 0;
  712. string TradeMonth = TradeDate.Substring(0, 6);
  713. string date = TradeDate.Substring(0, 4) + "-" + TradeDate.Substring(4, 2) + "-" + TradeDate.Substring(6, 2);
  714. string start = date + " 00:00:00";
  715. string end = DateTime.Parse(date).AddDays(1).ToString("yyyy-MM-dd") + " 00:00:00";
  716. Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  717. string ParentNav = user.ParentNav;
  718. UserTradeMonthSummary selfStat = db.UserTradeMonthSummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth && m.SeoKeyword == TradeDate && m.BrandId == BrandId && m.QueryCount == QrPayFlag && m.SeoTitle == "self");
  719. if (selfStat == null)
  720. {
  721. selfStat = db.UserTradeMonthSummary.Add(new UserTradeMonthSummary()
  722. {
  723. UserId = UserId,
  724. TradeMonth = TradeMonth,
  725. SeoKeyword = TradeDate,
  726. BrandId = BrandId,
  727. QueryCount = QrPayFlag,
  728. SeoTitle = "self",
  729. }).Entity;
  730. db.SaveChanges();
  731. }
  732. selfStat.ActiveBuddyMerStatus += ActCount;
  733. ParentNav += "," + UserId + ",";
  734. if (!string.IsNullOrEmpty(ParentNav))
  735. {
  736. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  737. foreach (string NavUserIdString in ParentNavList)
  738. {
  739. int NavUserId = int.Parse(NavUserIdString);
  740. UserTradeMonthSummary teamStat = db.UserTradeMonthSummary.FirstOrDefault(m => m.UserId == NavUserId && m.TradeMonth == TradeMonth && m.SeoKeyword == TradeDate && m.BrandId == BrandId && m.QueryCount == QrPayFlag && m.SeoTitle == "team");
  741. if (teamStat == null)
  742. {
  743. teamStat = db.UserTradeMonthSummary.Add(new UserTradeMonthSummary()
  744. {
  745. UserId = NavUserId,
  746. TradeMonth = TradeMonth,
  747. SeoKeyword = TradeDate,
  748. BrandId = BrandId,
  749. QueryCount = QrPayFlag,
  750. SeoTitle = "team",
  751. }).Entity;
  752. db.SaveChanges();
  753. }
  754. teamStat.ActiveBuddyMerStatus += ActCount;
  755. }
  756. }
  757. //统计分仓激活数
  758. StoreSnActivateSummary storeStat = db.StoreSnActivateSummary.FirstOrDefault(m => m.StoreId == StoreId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.BrandId == BrandId);
  759. if (storeStat == null)
  760. {
  761. storeStat = db.StoreSnActivateSummary.Add(new StoreSnActivateSummary()
  762. {
  763. StoreId = StoreId,
  764. TradeMonth = TradeMonth,
  765. TradeDate = TradeDate,
  766. BrandId = BrandId,
  767. }).Entity;
  768. db.SaveChanges();
  769. }
  770. storeStat.ActivateNum += ActCount;
  771. }
  772. db.SaveChanges();
  773. OtherMySqlConn.op("update PosMachinesTwo set QueryCount=1 where Id in (" + ids.TrimEnd(',') + ")");
  774. }
  775. }
  776. }
  777. catch (Exception ex)
  778. {
  779. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时执行创客激活数异常");
  780. }
  781. db.Dispose();
  782. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时执行创客激活数日志");
  783. }
  784. // 统计新增创客数
  785. public void StartNewUserNum()
  786. {
  787. Thread th = new Thread(StartNewUserNumFor);
  788. th.IsBackground = true;
  789. th.Start();
  790. }
  791. public void StartNewUserNumFor()
  792. {
  793. // DateTime end = DateTime.Parse("2022-06-15 00:00:00");
  794. // DateTime check = DateTime.Parse("2022-06-14");
  795. // while (check <= end)
  796. // {
  797. // StartNewUserNumDo(check.ToString("yyyy-MM-dd"));
  798. // check = check.AddDays(1);
  799. // }
  800. while (true)
  801. {
  802. if(DateTime.Now.Hour >= 3)
  803. {
  804. StartNewUserNumEverTime();
  805. }
  806. Thread.Sleep(120000);
  807. }
  808. }
  809. public void StartNewUserNumDo(object sender)
  810. {
  811. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  812. string date = sender.ToString();
  813. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "执行新增创客数日志");
  814. WebCMSEntities db = new WebCMSEntities();
  815. try
  816. {
  817. string StatDate = date.Replace("-", "");
  818. string StatMonth = StatDate.Substring(0, 6);
  819. string start = date + " 00:00:00";
  820. string end = DateTime.Parse(date).AddDays(1).ToString("yyyy-MM-dd") + " 00:00:00";
  821. List<string> uids = new List<string>();
  822. DataTable userDt = OtherMySqlConn.dtable("select Id,ParentNav from Users where QueryCount=0 and AuthFlag=1 and AuthDate>='" + start + "' and AuthDate<'" + end + "'");
  823. function.WriteLog("人数:" + userDt.Rows.Count + "\n\n", "执行新增创客数日志");
  824. foreach (DataRow userDr in userDt.Rows)
  825. {
  826. int UserId = int.Parse(userDr["Id"].ToString());
  827. string ParentNav = userDr["ParentNav"].ToString();
  828. function.WriteLog(UserId + ":" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行新增创客数日志");
  829. DataTable selfdt = OtherMySqlConn.dtable("select count(Id) from Users where QueryCount=0 and AuthFlag=1 and AuthDate>='" + start + "' and AuthDate<'" + end + "' and ParentUserId=" + UserId + "");
  830. function.WriteLog(UserId + ":" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行新增创客数日志");
  831. foreach (DataRow selfDr in selfdt.Rows)
  832. {
  833. int AddCount = int.Parse(selfDr[0].ToString());
  834. PullnewSummary selfStat = db.PullnewSummary.FirstOrDefault(m => m.UserId == UserId && m.StatMonth == StatMonth && m.StatDate == StatDate && m.SeoTitle == "self");
  835. if (selfStat == null)
  836. {
  837. selfStat = db.PullnewSummary.Add(new PullnewSummary()
  838. {
  839. UserId = UserId,
  840. StatMonth = StatMonth,
  841. StatDate = StatDate,
  842. SeoTitle = "self",
  843. }).Entity;
  844. db.SaveChanges();
  845. }
  846. selfStat.RecUserAuthNum += AddCount;
  847. db.SaveChanges();
  848. }
  849. if (!string.IsNullOrEmpty(ParentNav))
  850. {
  851. ParentNav += "," + UserId + ",";
  852. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  853. foreach (string NavUserIdString in ParentNavList)
  854. {
  855. if (!uids.Contains(NavUserIdString + start))
  856. {
  857. uids.Add(NavUserIdString + start);
  858. int NavUserId = int.Parse(NavUserIdString);
  859. function.WriteLog(NavUserId + ":team:" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行新增创客数日志");
  860. DataTable teamDt = OtherMySqlConn.dtable("select count(Id) from Users where QueryCount=0 and AuthFlag=1 and AuthDate>='" + start + "' and AuthDate<'" + end + "' and ParentNav like '%," + NavUserId + ",%'");
  861. function.WriteLog(NavUserId + ":team:" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行新增创客数日志");
  862. foreach (DataRow teamDr in teamDt.Rows)
  863. {
  864. int AddCount = int.Parse(teamDr[0].ToString());
  865. PullnewSummary teamStat = db.PullnewSummary.FirstOrDefault(m => m.UserId == NavUserId && m.StatMonth == StatMonth && m.StatDate == StatDate && m.SeoTitle == "team");
  866. if (teamStat == null)
  867. {
  868. teamStat = db.PullnewSummary.Add(new PullnewSummary()
  869. {
  870. UserId = NavUserId,
  871. StatMonth = StatMonth,
  872. StatDate = StatDate,
  873. SeoTitle = "team",
  874. }).Entity;
  875. db.SaveChanges();
  876. }
  877. teamStat.RecUserAuthNum += AddCount;
  878. db.SaveChanges();
  879. }
  880. }
  881. }
  882. }
  883. }
  884. OtherMySqlConn.op("update Users set QueryCount=1 where QueryCount=0 and AuthFlag=1 and AuthDate>='" + start + "' and AuthDate<'" + end + "'");
  885. }
  886. catch (Exception ex)
  887. {
  888. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "执行新增创客数异常");
  889. }
  890. db.Dispose();
  891. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行新增创客数日志");
  892. Thread.Sleep(60000);
  893. }
  894. public void StartNewUserNumEverTime()
  895. {
  896. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  897. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时执行新增创客数日志");
  898. WebCMSEntities db = new WebCMSEntities();
  899. try
  900. {
  901. DataTable idsDt = OtherMySqlConn.dtable("select Id from Users where QueryCount=0 and AuthFlag=1 and AuthDate is not null limit 50");
  902. if(idsDt.Rows.Count > 0)
  903. {
  904. string ids = "";
  905. foreach (DataRow idsDr in idsDt.Rows)
  906. {
  907. ids += idsDr["Id"].ToString() + ",";
  908. }
  909. DataTable userDt = OtherMySqlConn.dtable("select ParentUserId,DATE_FORMAT(AuthDate, '%Y%m%d'),count(Id) from Users where Id in (" + ids.TrimEnd(',') + ") group by ParentUserId,DATE_FORMAT(AuthDate, '%Y%m%d')");
  910. if(userDt.Rows.Count > 0)
  911. {
  912. function.WriteLog("人数:" + userDt.Rows.Count + "\n\n", "实时执行新增创客数日志");
  913. foreach (DataRow userDr in userDt.Rows)
  914. {
  915. string StatDate = userDr[1].ToString();
  916. int UserId = int.Parse(userDr["ParentUserId"].ToString());
  917. string StatMonth = StatDate.Substring(0, 6);
  918. string date = StatDate.Substring(0, 4) + "-" + StatDate.Substring(4, 2) + "-" + StatDate.Substring(6, 2);
  919. string start = date + " 00:00:00";
  920. string end = DateTime.Parse(date).AddDays(1).ToString("yyyy-MM-dd") + " 00:00:00";
  921. int AddCount = int.Parse(userDr[2].ToString());
  922. Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  923. string ParentNav = user.ParentNav;
  924. PullnewSummary selfStat = db.PullnewSummary.FirstOrDefault(m => m.UserId == UserId && m.StatMonth == StatMonth && m.StatDate == StatDate && m.SeoTitle == "self");
  925. if (selfStat == null)
  926. {
  927. selfStat = db.PullnewSummary.Add(new PullnewSummary()
  928. {
  929. UserId = UserId,
  930. StatMonth = StatMonth,
  931. StatDate = StatDate,
  932. SeoTitle = "self",
  933. }).Entity;
  934. db.SaveChanges();
  935. }
  936. selfStat.RecUserAuthNum += AddCount;
  937. ParentNav += "," + UserId + ",";
  938. if (!string.IsNullOrEmpty(ParentNav))
  939. {
  940. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  941. foreach (string NavUserIdString in ParentNavList)
  942. {
  943. int NavUserId = int.Parse(NavUserIdString);
  944. PullnewSummary teamStat = db.PullnewSummary.FirstOrDefault(m => m.UserId == NavUserId && m.StatMonth == StatMonth && m.StatDate == StatDate && m.SeoTitle == "team");
  945. if (teamStat == null)
  946. {
  947. teamStat = db.PullnewSummary.Add(new PullnewSummary()
  948. {
  949. UserId = NavUserId,
  950. StatMonth = StatMonth,
  951. StatDate = StatDate,
  952. SeoTitle = "team",
  953. }).Entity;
  954. db.SaveChanges();
  955. }
  956. teamStat.RecUserAuthNum += AddCount;
  957. }
  958. }
  959. }
  960. db.SaveChanges();
  961. OtherMySqlConn.op("update Users set QueryCount=1 where Id in (" + ids.TrimEnd(',') + ")");
  962. }
  963. }
  964. }
  965. catch (Exception ex)
  966. {
  967. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时执行新增创客数异常");
  968. }
  969. db.Dispose();
  970. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时执行新增创客数日志");
  971. }
  972. // 每天统计头一天的收益
  973. public void StatProfit()
  974. {
  975. Thread th = new Thread(StatProfitDo);
  976. th.IsBackground = true;
  977. th.Start();
  978. }
  979. public void StatProfitDo()
  980. {
  981. // DateTime end = DateTime.Parse("2022-06-16 00:00:00");
  982. // DateTime check = DateTime.Parse("2022-06-16");
  983. // while (check <= end)
  984. // {
  985. // StatProfitEverDay(check.ToString("yyyy-MM-dd"));
  986. // Thread.Sleep(1000);
  987. // check = check.AddDays(1);
  988. // }
  989. while (true)
  990. {
  991. if(DateTime.Now.Hour >= 3)
  992. {
  993. StatProfitEverDayEverTime();
  994. }
  995. Thread.Sleep(120000);
  996. }
  997. }
  998. public void StatProfitEverDay(object sender)
  999. {
  1000. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  1001. string date = sender.ToString();
  1002. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "执行昨天收益日志");
  1003. WebCMSEntities db = new WebCMSEntities();
  1004. try
  1005. {
  1006. string TradeDate = date.Replace("-", "");
  1007. string TradeMonth = TradeDate.Substring(0, 6);
  1008. string start = date + " 00:00:00";
  1009. string end = DateTime.Parse(date).AddDays(1).ToString("yyyy-MM-dd") + " 00:00:00";
  1010. string startId = "0";
  1011. List<string> uids = new List<string>();
  1012. DataTable startDt = OtherMySqlConn.dtable("select min(Id) from UserAccountRecord where CreateDate>='" + start + "'");
  1013. if (startDt.Rows.Count > 0)
  1014. {
  1015. startId = startDt.Rows[0][0].ToString();
  1016. }
  1017. function.WriteLog(startId + "\n\n", "执行昨天收益日志");
  1018. DataTable userDt = OtherMySqlConn.dtable("select Id,ParentNav from Users where Id in (select DISTINCT UserId from UserAccountRecord where Id>=" + startId + " and CreateDate>='" + start + "' and CreateDate<'" + end + "')");
  1019. function.WriteLog("交易人数:" + userDt.Rows.Count + "\n\n", "执行昨天收益日志");
  1020. foreach (DataRow userDr in userDt.Rows)
  1021. {
  1022. int UserId = int.Parse(userDr["Id"].ToString());
  1023. string ParentNav = userDr["ParentNav"].ToString();
  1024. function.WriteLog(UserId + ":" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行昨天收益日志");
  1025. DataTable selfdt = OtherMySqlConn.dtable("select ChangeType,ProductType,sum(ChangeAmount) from UserAccountRecord where Id>=" + startId + " and CreateDate>='" + start + "' and CreateDate<'" + end + "' and UserId=" + UserId + " group by ChangeType,ProductType");
  1026. function.WriteLog(UserId + ":" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行昨天收益日志");
  1027. foreach (DataRow selfDr in selfdt.Rows)
  1028. {
  1029. int ChangeType = int.Parse(selfDr["ChangeType"].ToString());
  1030. int ProductType = int.Parse(selfDr["ProductType"].ToString());
  1031. decimal ProfitAmount = decimal.Parse(selfDr[2].ToString());
  1032. UserRebateDetail selfStat = db.UserRebateDetail.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.RebateType == ChangeType && m.ProductType == ProductType && m.SeoTitle == "self");
  1033. if (selfStat == null)
  1034. {
  1035. selfStat = db.UserRebateDetail.Add(new UserRebateDetail()
  1036. {
  1037. UserId = UserId,
  1038. TradeMonth = TradeMonth,
  1039. TradeDate = TradeDate,
  1040. RebateType = ChangeType,
  1041. ProductType = ProductType,
  1042. SeoTitle = "self",
  1043. }).Entity;
  1044. db.SaveChanges();
  1045. }
  1046. selfStat.CreditRewardAmount += ProfitAmount;
  1047. db.SaveChanges();
  1048. }
  1049. if (!string.IsNullOrEmpty(ParentNav))
  1050. {
  1051. ParentNav += "," + UserId + ",";
  1052. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  1053. foreach (string NavUserIdString in ParentNavList)
  1054. {
  1055. if (!uids.Contains(NavUserIdString + start))
  1056. {
  1057. uids.Add(NavUserIdString + start);
  1058. int NavUserId = int.Parse(NavUserIdString);
  1059. function.WriteLog(NavUserId + ":team:" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行昨天收益日志");
  1060. DataTable teamDt = OtherMySqlConn.dtable("select ChangeType,ProductType,sum(ChangeAmount) from UserAccountRecord where Id>=" + startId + " and CreateDate>='" + start + "' and CreateDate<'" + end + "' and UserId in (select Id from Users where ParentNav like '%," + NavUserId + ",%' or Id=" + NavUserId + ") group by ChangeType,ProductType");
  1061. function.WriteLog(NavUserId + ":team:" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行昨天收益日志");
  1062. foreach (DataRow teamDr in teamDt.Rows)
  1063. {
  1064. int ChangeType = int.Parse(teamDr["ChangeType"].ToString());
  1065. int ProductType = int.Parse(teamDr["ProductType"].ToString());
  1066. decimal ProfitAmount = decimal.Parse(teamDr[2].ToString());
  1067. UserRebateDetail teamStat = db.UserRebateDetail.FirstOrDefault(m => m.UserId == NavUserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.RebateType == ChangeType && m.ProductType == ProductType && m.SeoTitle == "team");
  1068. if (teamStat == null)
  1069. {
  1070. teamStat = db.UserRebateDetail.Add(new UserRebateDetail()
  1071. {
  1072. UserId = NavUserId,
  1073. TradeMonth = TradeMonth,
  1074. TradeDate = TradeDate,
  1075. RebateType = ChangeType,
  1076. ProductType = ProductType,
  1077. SeoTitle = "team",
  1078. }).Entity;
  1079. db.SaveChanges();
  1080. }
  1081. teamStat.CreditRewardAmount += ProfitAmount;
  1082. db.SaveChanges();
  1083. }
  1084. }
  1085. }
  1086. }
  1087. }
  1088. }
  1089. catch (Exception ex)
  1090. {
  1091. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "统计昨天收益异常");
  1092. }
  1093. db.Dispose();
  1094. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行昨天收益日志");
  1095. }
  1096. public void StatProfitEverDayEverTime()
  1097. {
  1098. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  1099. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时统计收益日志");
  1100. WebCMSEntities db = new WebCMSEntities();
  1101. try
  1102. {
  1103. string startId = function.ReadInstance("/UserAccountRecord/Id.txt");
  1104. if(string.IsNullOrEmpty(startId))
  1105. {
  1106. startId = "160653";
  1107. }
  1108. DataTable idsDt = OtherMySqlConn.dtable("select Id from UserAccountRecord where Id>=" + startId + " and QueryCount=0 order by Id limit 50");
  1109. if(idsDt.Rows.Count > 0)
  1110. {
  1111. string ids = "";
  1112. foreach (DataRow idsDr in idsDt.Rows)
  1113. {
  1114. ids += idsDr["Id"].ToString() + ",";
  1115. startId = idsDr["Id"].ToString();
  1116. }
  1117. DataTable userDt = OtherMySqlConn.dtable("select UserId,ChangeType,ProductType,DATE_FORMAT(CreateDate, '%Y%m%d'),sum(ChangeAmount) from UserAccountRecord where Id in (" + ids.TrimEnd(',') + ") group by UserId,ChangeType,ProductType,DATE_FORMAT(CreateDate, '%Y%m%d')");
  1118. if (userDt.Rows.Count > 0)
  1119. {
  1120. function.WriteLog("收益人数:" + userDt.Rows.Count + "\n\n", "实时统计收益日志");
  1121. foreach (DataRow userDr in userDt.Rows)
  1122. {
  1123. int UserId = int.Parse(userDr["UserId"].ToString());
  1124. int ChangeType = int.Parse(userDr["ChangeType"].ToString());
  1125. int ProductType = int.Parse(userDr["ProductType"].ToString());
  1126. string TradeDate = userDr[3].ToString();
  1127. decimal ProfitAmount = decimal.Parse(userDr[4].ToString());
  1128. string TradeMonth = TradeDate.Substring(0, 6);
  1129. string date = TradeDate.Substring(0, 4) + "-" + TradeDate.Substring(4, 2) + "-" + TradeDate.Substring(6, 2);
  1130. string start = date + " 00:00:00";
  1131. string end = DateTime.Parse(date).AddDays(1).ToString("yyyy-MM-dd") + " 00:00:00";
  1132. Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  1133. string ParentNav = user.ParentNav;
  1134. UserRebateDetail selfStat = db.UserRebateDetail.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.RebateType == ChangeType && m.ProductType == ProductType && m.SeoTitle == "self");
  1135. if (selfStat == null)
  1136. {
  1137. selfStat = db.UserRebateDetail.Add(new UserRebateDetail()
  1138. {
  1139. UserId = UserId,
  1140. TradeMonth = TradeMonth,
  1141. TradeDate = TradeDate,
  1142. RebateType = ChangeType,
  1143. ProductType = ProductType,
  1144. SeoTitle = "self",
  1145. }).Entity;
  1146. db.SaveChanges();
  1147. }
  1148. selfStat.CreditRewardAmount += ProfitAmount;
  1149. ParentNav += "," + UserId + ",";
  1150. if (!string.IsNullOrEmpty(ParentNav))
  1151. {
  1152. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  1153. foreach (string NavUserIdString in ParentNavList)
  1154. {
  1155. int NavUserId = int.Parse(NavUserIdString);
  1156. UserRebateDetail teamStat = db.UserRebateDetail.FirstOrDefault(m => m.UserId == NavUserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.RebateType == ChangeType && m.ProductType == ProductType && m.SeoTitle == "team");
  1157. if (teamStat == null)
  1158. {
  1159. teamStat = db.UserRebateDetail.Add(new UserRebateDetail()
  1160. {
  1161. UserId = NavUserId,
  1162. TradeMonth = TradeMonth,
  1163. TradeDate = TradeDate,
  1164. RebateType = ChangeType,
  1165. ProductType = ProductType,
  1166. SeoTitle = "team",
  1167. }).Entity;
  1168. db.SaveChanges();
  1169. }
  1170. teamStat.CreditRewardAmount += ProfitAmount;
  1171. }
  1172. }
  1173. }
  1174. db.SaveChanges();
  1175. OtherMySqlConn.op("update UserAccountRecord set QueryCount=1 where Id in (" + ids.TrimEnd(',') + ")");
  1176. function.WritePage("/UserAccountRecord/", "Id.txt", startId);
  1177. }
  1178. }
  1179. }
  1180. catch (Exception ex)
  1181. {
  1182. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时统计收益异常");
  1183. }
  1184. db.Dispose();
  1185. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时统计收益日志");
  1186. }
  1187. #region 判断品牌互斥条件,根据身份证号
  1188. public bool CheckRepeatByBrand(WebCMSEntities db, int MerchantId)
  1189. {
  1190. int check = db.PosMachinesTwo.Count(m => m.Status > -1 && m.BindMerchantId == MerchantId);
  1191. return false;
  1192. }
  1193. #endregion
  1194. }
  1195. }