StatService.cs 72 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213
  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(RedisDbconn.Instance.Get<string>("StatServerStatus") == "1" && 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. while (true)
  577. {
  578. if(RedisDbconn.Instance.Get<string>("StatServerStatus") == "1" && DateTime.Now.Hour >= 3)
  579. {
  580. StartPosActNumEverTime();
  581. StatBusinessService.Instance.StartPosActNumEverTime();
  582. }
  583. Thread.Sleep(120000);
  584. }
  585. }
  586. public void StartPosActNumDo(object sender)
  587. {
  588. string date = sender.ToString();
  589. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "执行创客激活数日志");
  590. WebCMSEntities db = new WebCMSEntities();
  591. try
  592. {
  593. string TradeDate = date.Replace("-", "");
  594. string TradeMonth = TradeDate.Substring(0, 6);
  595. string start = date + " 00:00:00";
  596. string end = DateTime.Parse(date).AddDays(1).ToString("yyyy-MM-dd") + " 00:00:00";
  597. List<string> uids = new List<string>();
  598. 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 + "')");
  599. function.WriteLog("人数:" + userDt.Rows.Count + "\n\n", "执行创客激活数日志");
  600. foreach (DataRow userDr in userDt.Rows)
  601. {
  602. int UserId = int.Parse(userDr["Id"].ToString());
  603. string ParentNav = userDr["ParentNav"].ToString();
  604. function.WriteLog(UserId + ":" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行创客激活数日志");
  605. 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");
  606. function.WriteLog(UserId + ":" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行创客激活数日志");
  607. foreach (DataRow selfDr in selfdt.Rows)
  608. {
  609. int BrandId = int.Parse(selfDr["BrandId"].ToString());
  610. int QrPayFlag = 0;
  611. int ActCount = int.Parse(selfDr[1].ToString());
  612. UserTradeDaySummary selfStat = db.UserTradeDaySummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.BrandId == BrandId && m.QueryCount == QrPayFlag && m.SeoTitle == "self");
  613. if (selfStat == null)
  614. {
  615. selfStat = db.UserTradeDaySummary.Add(new UserTradeDaySummary()
  616. {
  617. UserId = UserId,
  618. TradeMonth = TradeMonth,
  619. TradeDate = TradeDate,
  620. BrandId = BrandId,
  621. QueryCount = QrPayFlag,
  622. SeoTitle = "self",
  623. }).Entity;
  624. db.SaveChanges();
  625. }
  626. selfStat.DirectDebitCapNum += ActCount;
  627. db.SaveChanges();
  628. }
  629. if (!string.IsNullOrEmpty(ParentNav))
  630. {
  631. ParentNav += "," + UserId + ",";
  632. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  633. foreach (string NavUserIdString in ParentNavList)
  634. {
  635. if (!uids.Contains(NavUserIdString + start))
  636. {
  637. uids.Add(NavUserIdString + start);
  638. int NavUserId = int.Parse(NavUserIdString);
  639. function.WriteLog(NavUserId + ":team:" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行创客激活数日志");
  640. 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");
  641. function.WriteLog(NavUserId + ":team:" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行创客激活数日志");
  642. foreach (DataRow teamDr in teamDt.Rows)
  643. {
  644. int BrandId = int.Parse(teamDr["BrandId"].ToString());
  645. int QrPayFlag = 0;
  646. int ActCount = int.Parse(teamDr[1].ToString());
  647. UserTradeDaySummary teamStat = db.UserTradeDaySummary.FirstOrDefault(m => m.UserId == NavUserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.BrandId == BrandId && m.QueryCount == QrPayFlag && m.SeoTitle == "team");
  648. if (teamStat == null)
  649. {
  650. teamStat = db.UserTradeDaySummary.Add(new UserTradeDaySummary()
  651. {
  652. UserId = NavUserId,
  653. TradeMonth = TradeMonth,
  654. TradeDate = TradeDate,
  655. BrandId = BrandId,
  656. QueryCount = QrPayFlag,
  657. SeoTitle = "team",
  658. }).Entity;
  659. db.SaveChanges();
  660. }
  661. teamStat.NonDirectDebitCapNum += ActCount;
  662. db.SaveChanges();
  663. }
  664. }
  665. }
  666. }
  667. }
  668. OtherMySqlConn.op("update PosMachinesTwo set QueryCount=1 where QueryCount=0 and ActivationState=1 and ActivationTime>='" + start + "' and ActivationTime<'" + end + "'");
  669. }
  670. catch (Exception ex)
  671. {
  672. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "执行创客激活数异常");
  673. }
  674. db.Dispose();
  675. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行创客激活数日志");
  676. Thread.Sleep(60000);
  677. }
  678. public void StartPosActNumEverTime()
  679. {
  680. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  681. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时执行创客激活数日志");
  682. WebCMSEntities db = new WebCMSEntities();
  683. try
  684. {
  685. 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");
  686. if(idsDt.Rows.Count > 0)
  687. {
  688. string ids = "";
  689. foreach (DataRow idsDr in idsDt.Rows)
  690. {
  691. ids += idsDr["Id"].ToString() + ",";
  692. }
  693. 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')");
  694. if (userDt.Rows.Count > 0)
  695. {
  696. function.WriteLog("人数:" + userDt.Rows.Count + "\n\n", "实时执行创客激活数日志");
  697. foreach (DataRow userDr in userDt.Rows)
  698. {
  699. int UserId = int.Parse(userDr["BuyUserId"].ToString());
  700. int StoreId = int.Parse(userDr["StoreId"].ToString());
  701. int BrandId = int.Parse(userDr["BrandId"].ToString());
  702. string TradeDate = userDr[3].ToString();
  703. int ActCount = int.Parse(function.CheckInt(userDr[4].ToString()));
  704. int QrPayFlag = 0;
  705. string TradeMonth = TradeDate.Substring(0, 6);
  706. string date = TradeDate.Substring(0, 4) + "-" + TradeDate.Substring(4, 2) + "-" + TradeDate.Substring(6, 2);
  707. string start = date + " 00:00:00";
  708. string end = DateTime.Parse(date).AddDays(1).ToString("yyyy-MM-dd") + " 00:00:00";
  709. Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  710. string ParentNav = user.ParentNav;
  711. UserTradeMonthSummary selfStat = db.UserTradeMonthSummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth && m.SeoKeyword == TradeDate && m.BrandId == BrandId && m.QueryCount == QrPayFlag && m.SeoTitle == "self");
  712. if (selfStat == null)
  713. {
  714. selfStat = db.UserTradeMonthSummary.Add(new UserTradeMonthSummary()
  715. {
  716. UserId = UserId,
  717. TradeMonth = TradeMonth,
  718. SeoKeyword = TradeDate,
  719. BrandId = BrandId,
  720. QueryCount = QrPayFlag,
  721. SeoTitle = "self",
  722. }).Entity;
  723. db.SaveChanges();
  724. }
  725. selfStat.ActiveBuddyMerStatus += ActCount;
  726. ParentNav += "," + UserId + ",";
  727. if (!string.IsNullOrEmpty(ParentNav))
  728. {
  729. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  730. foreach (string NavUserIdString in ParentNavList)
  731. {
  732. int NavUserId = int.Parse(NavUserIdString);
  733. UserTradeMonthSummary teamStat = db.UserTradeMonthSummary.FirstOrDefault(m => m.UserId == NavUserId && m.TradeMonth == TradeMonth && m.SeoKeyword == TradeDate && m.BrandId == BrandId && m.QueryCount == QrPayFlag && m.SeoTitle == "team");
  734. if (teamStat == null)
  735. {
  736. teamStat = db.UserTradeMonthSummary.Add(new UserTradeMonthSummary()
  737. {
  738. UserId = NavUserId,
  739. TradeMonth = TradeMonth,
  740. SeoKeyword = TradeDate,
  741. BrandId = BrandId,
  742. QueryCount = QrPayFlag,
  743. SeoTitle = "team",
  744. }).Entity;
  745. db.SaveChanges();
  746. }
  747. teamStat.ActiveBuddyMerStatus += ActCount;
  748. }
  749. }
  750. //统计分仓激活数
  751. StoreSnActivateSummary storeStat = db.StoreSnActivateSummary.FirstOrDefault(m => m.StoreId == StoreId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.BrandId == BrandId);
  752. if (storeStat == null)
  753. {
  754. storeStat = db.StoreSnActivateSummary.Add(new StoreSnActivateSummary()
  755. {
  756. StoreId = StoreId,
  757. TradeMonth = TradeMonth,
  758. TradeDate = TradeDate,
  759. BrandId = BrandId,
  760. }).Entity;
  761. db.SaveChanges();
  762. }
  763. storeStat.ActivateNum += ActCount;
  764. }
  765. db.SaveChanges();
  766. OtherMySqlConn.op("update PosMachinesTwo set QueryCount=1 where Id in (" + ids.TrimEnd(',') + ")");
  767. }
  768. }
  769. }
  770. catch (Exception ex)
  771. {
  772. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时执行创客激活数异常");
  773. }
  774. db.Dispose();
  775. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时执行创客激活数日志");
  776. }
  777. // 统计新增创客数
  778. public void StartNewUserNum()
  779. {
  780. Thread th = new Thread(StartNewUserNumFor);
  781. th.IsBackground = true;
  782. th.Start();
  783. }
  784. public void StartNewUserNumFor()
  785. {
  786. while (true)
  787. {
  788. if(RedisDbconn.Instance.Get<string>("StatServerStatus") == "1" && DateTime.Now.Hour >= 3)
  789. {
  790. StartNewUserNumEverTime();
  791. }
  792. Thread.Sleep(120000);
  793. }
  794. }
  795. public void StartNewUserNumDo(object sender)
  796. {
  797. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  798. string date = sender.ToString();
  799. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "执行新增创客数日志");
  800. WebCMSEntities db = new WebCMSEntities();
  801. try
  802. {
  803. string StatDate = date.Replace("-", "");
  804. string StatMonth = StatDate.Substring(0, 6);
  805. string start = date + " 00:00:00";
  806. string end = DateTime.Parse(date).AddDays(1).ToString("yyyy-MM-dd") + " 00:00:00";
  807. List<string> uids = new List<string>();
  808. DataTable userDt = OtherMySqlConn.dtable("select Id,ParentNav from Users where QueryCount=0 and AuthFlag=1 and AuthDate>='" + start + "' and AuthDate<'" + end + "'");
  809. function.WriteLog("人数:" + userDt.Rows.Count + "\n\n", "执行新增创客数日志");
  810. foreach (DataRow userDr in userDt.Rows)
  811. {
  812. int UserId = int.Parse(userDr["Id"].ToString());
  813. string ParentNav = userDr["ParentNav"].ToString();
  814. function.WriteLog(UserId + ":" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行新增创客数日志");
  815. DataTable selfdt = OtherMySqlConn.dtable("select count(Id) from Users where QueryCount=0 and AuthFlag=1 and AuthDate>='" + start + "' and AuthDate<'" + end + "' and ParentUserId=" + UserId + "");
  816. function.WriteLog(UserId + ":" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行新增创客数日志");
  817. foreach (DataRow selfDr in selfdt.Rows)
  818. {
  819. int AddCount = int.Parse(selfDr[0].ToString());
  820. PullnewSummary selfStat = db.PullnewSummary.FirstOrDefault(m => m.UserId == UserId && m.StatMonth == StatMonth && m.StatDate == StatDate && m.SeoTitle == "self");
  821. if (selfStat == null)
  822. {
  823. selfStat = db.PullnewSummary.Add(new PullnewSummary()
  824. {
  825. UserId = UserId,
  826. StatMonth = StatMonth,
  827. StatDate = StatDate,
  828. SeoTitle = "self",
  829. }).Entity;
  830. db.SaveChanges();
  831. }
  832. selfStat.RecUserAuthNum += AddCount;
  833. db.SaveChanges();
  834. }
  835. if (!string.IsNullOrEmpty(ParentNav))
  836. {
  837. ParentNav += "," + UserId + ",";
  838. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  839. foreach (string NavUserIdString in ParentNavList)
  840. {
  841. if (!uids.Contains(NavUserIdString + start))
  842. {
  843. uids.Add(NavUserIdString + start);
  844. int NavUserId = int.Parse(NavUserIdString);
  845. function.WriteLog(NavUserId + ":team:" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行新增创客数日志");
  846. 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 + ",%'");
  847. function.WriteLog(NavUserId + ":team:" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行新增创客数日志");
  848. foreach (DataRow teamDr in teamDt.Rows)
  849. {
  850. int AddCount = int.Parse(teamDr[0].ToString());
  851. PullnewSummary teamStat = db.PullnewSummary.FirstOrDefault(m => m.UserId == NavUserId && m.StatMonth == StatMonth && m.StatDate == StatDate && m.SeoTitle == "team");
  852. if (teamStat == null)
  853. {
  854. teamStat = db.PullnewSummary.Add(new PullnewSummary()
  855. {
  856. UserId = NavUserId,
  857. StatMonth = StatMonth,
  858. StatDate = StatDate,
  859. SeoTitle = "team",
  860. }).Entity;
  861. db.SaveChanges();
  862. }
  863. teamStat.RecUserAuthNum += AddCount;
  864. db.SaveChanges();
  865. }
  866. }
  867. }
  868. }
  869. }
  870. OtherMySqlConn.op("update Users set QueryCount=1 where QueryCount=0 and AuthFlag=1 and AuthDate>='" + start + "' and AuthDate<'" + end + "'");
  871. }
  872. catch (Exception ex)
  873. {
  874. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "执行新增创客数异常");
  875. }
  876. db.Dispose();
  877. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行新增创客数日志");
  878. Thread.Sleep(60000);
  879. }
  880. public void StartNewUserNumEverTime()
  881. {
  882. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  883. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时执行新增创客数日志");
  884. WebCMSEntities db = new WebCMSEntities();
  885. try
  886. {
  887. DataTable idsDt = OtherMySqlConn.dtable("select Id from Users where QueryCount=0 and AuthFlag=1 and AuthDate is not null limit 50");
  888. if(idsDt.Rows.Count > 0)
  889. {
  890. string ids = "";
  891. foreach (DataRow idsDr in idsDt.Rows)
  892. {
  893. ids += idsDr["Id"].ToString() + ",";
  894. }
  895. 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')");
  896. if(userDt.Rows.Count > 0)
  897. {
  898. function.WriteLog("人数:" + userDt.Rows.Count + "\n\n", "实时执行新增创客数日志");
  899. foreach (DataRow userDr in userDt.Rows)
  900. {
  901. string StatDate = userDr[1].ToString();
  902. int UserId = int.Parse(userDr["ParentUserId"].ToString());
  903. string StatMonth = StatDate.Substring(0, 6);
  904. string date = StatDate.Substring(0, 4) + "-" + StatDate.Substring(4, 2) + "-" + StatDate.Substring(6, 2);
  905. string start = date + " 00:00:00";
  906. string end = DateTime.Parse(date).AddDays(1).ToString("yyyy-MM-dd") + " 00:00:00";
  907. int AddCount = int.Parse(userDr[2].ToString());
  908. Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  909. string ParentNav = user.ParentNav;
  910. PullnewSummary selfStat = db.PullnewSummary.FirstOrDefault(m => m.UserId == UserId && m.StatMonth == StatMonth && m.StatDate == StatDate && m.SeoTitle == "self");
  911. if (selfStat == null)
  912. {
  913. selfStat = db.PullnewSummary.Add(new PullnewSummary()
  914. {
  915. UserId = UserId,
  916. StatMonth = StatMonth,
  917. StatDate = StatDate,
  918. SeoTitle = "self",
  919. }).Entity;
  920. db.SaveChanges();
  921. }
  922. selfStat.RecUserAuthNum += AddCount;
  923. ParentNav += "," + UserId + ",";
  924. if (!string.IsNullOrEmpty(ParentNav))
  925. {
  926. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  927. foreach (string NavUserIdString in ParentNavList)
  928. {
  929. int NavUserId = int.Parse(NavUserIdString);
  930. PullnewSummary teamStat = db.PullnewSummary.FirstOrDefault(m => m.UserId == NavUserId && m.StatMonth == StatMonth && m.StatDate == StatDate && m.SeoTitle == "team");
  931. if (teamStat == null)
  932. {
  933. teamStat = db.PullnewSummary.Add(new PullnewSummary()
  934. {
  935. UserId = NavUserId,
  936. StatMonth = StatMonth,
  937. StatDate = StatDate,
  938. SeoTitle = "team",
  939. }).Entity;
  940. db.SaveChanges();
  941. }
  942. teamStat.RecUserAuthNum += AddCount;
  943. }
  944. }
  945. }
  946. db.SaveChanges();
  947. OtherMySqlConn.op("update Users set QueryCount=1 where Id in (" + ids.TrimEnd(',') + ")");
  948. }
  949. }
  950. }
  951. catch (Exception ex)
  952. {
  953. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时执行新增创客数异常");
  954. }
  955. db.Dispose();
  956. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时执行新增创客数日志");
  957. }
  958. // 每天统计头一天的收益
  959. public void StatProfit()
  960. {
  961. Thread th = new Thread(StatProfitDo);
  962. th.IsBackground = true;
  963. th.Start();
  964. }
  965. public void StatProfitDo()
  966. {
  967. while (true)
  968. {
  969. if(RedisDbconn.Instance.Get<string>("StatServerStatus") == "1" && DateTime.Now.Hour >= 3)
  970. {
  971. StatProfitEverDayEverTime();
  972. }
  973. Thread.Sleep(120000);
  974. }
  975. }
  976. public void StatProfitEverDay(object sender)
  977. {
  978. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  979. string date = sender.ToString();
  980. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "执行昨天收益日志");
  981. WebCMSEntities db = new WebCMSEntities();
  982. try
  983. {
  984. string TradeDate = date.Replace("-", "");
  985. string TradeMonth = TradeDate.Substring(0, 6);
  986. string start = date + " 00:00:00";
  987. string end = DateTime.Parse(date).AddDays(1).ToString("yyyy-MM-dd") + " 00:00:00";
  988. string startId = "0";
  989. List<string> uids = new List<string>();
  990. DataTable startDt = OtherMySqlConn.dtable("select min(Id) from UserAccountRecord where CreateDate>='" + start + "'");
  991. if (startDt.Rows.Count > 0)
  992. {
  993. startId = startDt.Rows[0][0].ToString();
  994. }
  995. function.WriteLog(startId + "\n\n", "执行昨天收益日志");
  996. 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 + "')");
  997. function.WriteLog("交易人数:" + userDt.Rows.Count + "\n\n", "执行昨天收益日志");
  998. foreach (DataRow userDr in userDt.Rows)
  999. {
  1000. int UserId = int.Parse(userDr["Id"].ToString());
  1001. string ParentNav = userDr["ParentNav"].ToString();
  1002. function.WriteLog(UserId + ":" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行昨天收益日志");
  1003. 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");
  1004. function.WriteLog(UserId + ":" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行昨天收益日志");
  1005. foreach (DataRow selfDr in selfdt.Rows)
  1006. {
  1007. int ChangeType = int.Parse(selfDr["ChangeType"].ToString());
  1008. int ProductType = int.Parse(selfDr["ProductType"].ToString());
  1009. decimal ProfitAmount = decimal.Parse(selfDr[2].ToString());
  1010. UserRebateDetail selfStat = db.UserRebateDetail.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.RebateType == ChangeType && m.ProductType == ProductType && m.SeoTitle == "self");
  1011. if (selfStat == null)
  1012. {
  1013. selfStat = db.UserRebateDetail.Add(new UserRebateDetail()
  1014. {
  1015. UserId = UserId,
  1016. TradeMonth = TradeMonth,
  1017. TradeDate = TradeDate,
  1018. RebateType = ChangeType,
  1019. ProductType = ProductType,
  1020. SeoTitle = "self",
  1021. }).Entity;
  1022. db.SaveChanges();
  1023. }
  1024. selfStat.CreditRewardAmount += ProfitAmount;
  1025. db.SaveChanges();
  1026. }
  1027. if (!string.IsNullOrEmpty(ParentNav))
  1028. {
  1029. ParentNav += "," + UserId + ",";
  1030. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  1031. foreach (string NavUserIdString in ParentNavList)
  1032. {
  1033. if (!uids.Contains(NavUserIdString + start))
  1034. {
  1035. uids.Add(NavUserIdString + start);
  1036. int NavUserId = int.Parse(NavUserIdString);
  1037. function.WriteLog(NavUserId + ":team:" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行昨天收益日志");
  1038. 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");
  1039. function.WriteLog(NavUserId + ":team:" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行昨天收益日志");
  1040. foreach (DataRow teamDr in teamDt.Rows)
  1041. {
  1042. int ChangeType = int.Parse(teamDr["ChangeType"].ToString());
  1043. int ProductType = int.Parse(teamDr["ProductType"].ToString());
  1044. decimal ProfitAmount = decimal.Parse(teamDr[2].ToString());
  1045. UserRebateDetail teamStat = db.UserRebateDetail.FirstOrDefault(m => m.UserId == NavUserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.RebateType == ChangeType && m.ProductType == ProductType && m.SeoTitle == "team");
  1046. if (teamStat == null)
  1047. {
  1048. teamStat = db.UserRebateDetail.Add(new UserRebateDetail()
  1049. {
  1050. UserId = NavUserId,
  1051. TradeMonth = TradeMonth,
  1052. TradeDate = TradeDate,
  1053. RebateType = ChangeType,
  1054. ProductType = ProductType,
  1055. SeoTitle = "team",
  1056. }).Entity;
  1057. db.SaveChanges();
  1058. }
  1059. teamStat.CreditRewardAmount += ProfitAmount;
  1060. db.SaveChanges();
  1061. }
  1062. }
  1063. }
  1064. }
  1065. }
  1066. }
  1067. catch (Exception ex)
  1068. {
  1069. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "统计昨天收益异常");
  1070. }
  1071. db.Dispose();
  1072. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "执行昨天收益日志");
  1073. }
  1074. public void StatProfitEverDayEverTime()
  1075. {
  1076. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  1077. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时统计收益日志");
  1078. WebCMSEntities db = new WebCMSEntities();
  1079. try
  1080. {
  1081. string startId = function.ReadInstance("/UserAccountRecord/Id.txt");
  1082. if(string.IsNullOrEmpty(startId))
  1083. {
  1084. startId = "160653";
  1085. }
  1086. DataTable idsDt = OtherMySqlConn.dtable("select Id from UserAccountRecord where Id>=" + startId + " and QueryCount=0 order by Id limit 50");
  1087. if(idsDt.Rows.Count > 0)
  1088. {
  1089. string ids = "";
  1090. foreach (DataRow idsDr in idsDt.Rows)
  1091. {
  1092. ids += idsDr["Id"].ToString() + ",";
  1093. startId = idsDr["Id"].ToString();
  1094. }
  1095. 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')");
  1096. if (userDt.Rows.Count > 0)
  1097. {
  1098. function.WriteLog("收益人数:" + userDt.Rows.Count + "\n\n", "实时统计收益日志");
  1099. foreach (DataRow userDr in userDt.Rows)
  1100. {
  1101. int UserId = int.Parse(userDr["UserId"].ToString());
  1102. int ChangeType = int.Parse(userDr["ChangeType"].ToString());
  1103. int ProductType = int.Parse(userDr["ProductType"].ToString());
  1104. string TradeDate = userDr[3].ToString();
  1105. decimal ProfitAmount = decimal.Parse(userDr[4].ToString());
  1106. string TradeMonth = TradeDate.Substring(0, 6);
  1107. string date = TradeDate.Substring(0, 4) + "-" + TradeDate.Substring(4, 2) + "-" + TradeDate.Substring(6, 2);
  1108. string start = date + " 00:00:00";
  1109. string end = DateTime.Parse(date).AddDays(1).ToString("yyyy-MM-dd") + " 00:00:00";
  1110. Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  1111. string ParentNav = user.ParentNav;
  1112. UserRebateDetail selfStat = db.UserRebateDetail.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.RebateType == ChangeType && m.ProductType == ProductType && m.SeoTitle == "self");
  1113. if (selfStat == null)
  1114. {
  1115. selfStat = db.UserRebateDetail.Add(new UserRebateDetail()
  1116. {
  1117. UserId = UserId,
  1118. TradeMonth = TradeMonth,
  1119. TradeDate = TradeDate,
  1120. RebateType = ChangeType,
  1121. ProductType = ProductType,
  1122. SeoTitle = "self",
  1123. }).Entity;
  1124. db.SaveChanges();
  1125. }
  1126. selfStat.CreditRewardAmount += ProfitAmount;
  1127. ParentNav += "," + UserId + ",";
  1128. if (!string.IsNullOrEmpty(ParentNav))
  1129. {
  1130. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  1131. foreach (string NavUserIdString in ParentNavList)
  1132. {
  1133. int NavUserId = int.Parse(NavUserIdString);
  1134. UserRebateDetail teamStat = db.UserRebateDetail.FirstOrDefault(m => m.UserId == NavUserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.RebateType == ChangeType && m.ProductType == ProductType && m.SeoTitle == "team");
  1135. if (teamStat == null)
  1136. {
  1137. teamStat = db.UserRebateDetail.Add(new UserRebateDetail()
  1138. {
  1139. UserId = NavUserId,
  1140. TradeMonth = TradeMonth,
  1141. TradeDate = TradeDate,
  1142. RebateType = ChangeType,
  1143. ProductType = ProductType,
  1144. SeoTitle = "team",
  1145. }).Entity;
  1146. db.SaveChanges();
  1147. }
  1148. teamStat.CreditRewardAmount += ProfitAmount;
  1149. }
  1150. }
  1151. }
  1152. db.SaveChanges();
  1153. OtherMySqlConn.op("update UserAccountRecord set QueryCount=1 where Id in (" + ids.TrimEnd(',') + ")");
  1154. function.WritePage("/UserAccountRecord/", "Id.txt", startId);
  1155. }
  1156. }
  1157. }
  1158. catch (Exception ex)
  1159. {
  1160. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时统计收益异常");
  1161. }
  1162. db.Dispose();
  1163. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时统计收益日志");
  1164. }
  1165. #region 判断品牌互斥条件,根据身份证号
  1166. public bool CheckRepeatByBrand(WebCMSEntities db, int MerchantId)
  1167. {
  1168. int check = db.PosMachinesTwo.Count(m => m.Status > -1 && m.BindMerchantId == MerchantId);
  1169. return false;
  1170. }
  1171. #endregion
  1172. }
  1173. }