StatHelpProfitService.cs 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517
  1. using System;
  2. using System.Collections.Generic;
  3. using Library;
  4. using LitJson;
  5. using System.Linq;
  6. using System.Data;
  7. using System.Threading;
  8. using MySystem.PxcModels;
  9. namespace MySystem
  10. {
  11. public class StatHelpProfitService
  12. {
  13. public readonly static StatHelpProfitService Instance = new StatHelpProfitService();
  14. private StatHelpProfitService()
  15. { }
  16. // 统计交易额V2
  17. public void StartEverDayV2()
  18. {
  19. Thread th = new Thread(StartEverDayV2Do);
  20. th.IsBackground = true;
  21. th.Start();
  22. }
  23. public void StartEverDayV2Do()
  24. {
  25. while (true)
  26. {
  27. if (DateTime.Now.Hour >= 3)
  28. {
  29. StatTradeAmountEverDayV2();
  30. }
  31. Thread.Sleep(30000);
  32. }
  33. }
  34. public void StatTradeAmountEverDayV2()
  35. {
  36. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  37. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时执行助利宝交易额日志");
  38. WebCMSEntities db = new WebCMSEntities();
  39. using (var tran = db.Database.BeginTransaction())
  40. {
  41. try
  42. {
  43. string startId = function.ReadInstance("/TradeRecord/Id3.txt");
  44. if (string.IsNullOrEmpty(startId))
  45. {
  46. startId = "2750000";
  47. }
  48. DataTable idsDt = OtherMySqlConn.dtable("select Id from TradeRecord where Id>=" + startId + " and CreateDate>='2022-09-05 00:00:00' and MerchantId in (select MerchantId from HelpProfitMerIds) and SeoTitle='HelpProfit' and QueryCount>0 and QueryCount<3 order by Id limit 50");
  49. if (idsDt.Rows.Count > 0)
  50. {
  51. string ids = "";
  52. foreach (DataRow idsDr in idsDt.Rows)
  53. {
  54. ids += idsDr["Id"].ToString() + ",";
  55. startId = idsDr["Id"].ToString();
  56. }
  57. DataTable selfDt = OtherMySqlConn.dtable("select MerchantId,DATE_FORMAT(CreateDate,'%Y%m%d'),sum(TradeAmount) from TradeRecord where Id in (" + ids.TrimEnd(',') + ") group by MerchantId,DATE_FORMAT(CreateDate,'%Y%m%d')");
  58. if (selfDt.Rows.Count > 0)
  59. {
  60. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "实时执行助利宝交易额日志");
  61. foreach (DataRow selfDr in selfDt.Rows)
  62. {
  63. int MerchantId = int.Parse(selfDr["MerchantId"].ToString());
  64. string TradeDate = selfDr[1].ToString();
  65. string TradeMonth = TradeDate.Substring(0, 6);
  66. decimal TradeAmount = decimal.Parse(selfDr[2].ToString());
  67. HelpProfitMerIds merIds = db.HelpProfitMerIds.FirstOrDefault(m => m.MerchantId == MerchantId) ?? new HelpProfitMerIds();
  68. bool Check = CheckAmount(db, MerchantId, merIds.UserId, TradeMonth);
  69. if (Check)
  70. {
  71. decimal MoreAmount = TradeAmount * 0.01M;
  72. int random = function.get_Random(0, 10000);
  73. // if(MoreAmount > 1 && random < 5000)
  74. // {
  75. MoreAmount = decimal.Parse(function.CheckInt(MoreAmount.ToString().Split(".")[0]));
  76. // }
  77. HelpProfitMerTradeSummay selfStat = db.HelpProfitMerTradeSummay.FirstOrDefault(m => m.MerchantId == MerchantId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate);
  78. if (selfStat == null)
  79. {
  80. selfStat = db.HelpProfitMerTradeSummay.Add(new HelpProfitMerTradeSummay()
  81. {
  82. TradeMonth = TradeMonth,
  83. TradeDate = TradeDate,
  84. MerchantId = MerchantId,
  85. }).Entity;
  86. db.SaveChanges();
  87. }
  88. selfStat.TradeAmount += TradeAmount + MoreAmount;
  89. HelpProfitMerTradeMonthSummay monthStat = db.HelpProfitMerTradeMonthSummay.FirstOrDefault(m => m.MerchantId == MerchantId && m.TradeMonth == TradeMonth);
  90. if (monthStat == null)
  91. {
  92. monthStat = db.HelpProfitMerTradeMonthSummay.Add(new HelpProfitMerTradeMonthSummay()
  93. {
  94. TradeMonth = TradeMonth,
  95. MerchantId = MerchantId,
  96. }).Entity;
  97. db.SaveChanges();
  98. }
  99. monthStat.TradeAmount += TradeAmount + MoreAmount;
  100. HelpProfitAmountSummary amountStat = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == merIds.UserId && m.TradeMonth == TradeMonth);
  101. if (amountStat == null)
  102. {
  103. amountStat = db.HelpProfitAmountSummary.Add(new HelpProfitAmountSummary()
  104. {
  105. TradeMonth = TradeMonth,
  106. UserId = merIds.UserId,
  107. }).Entity;
  108. db.SaveChanges();
  109. }
  110. amountStat.TradeAmount += TradeAmount + MoreAmount;
  111. }
  112. }
  113. OtherMySqlConn.op("update TradeRecord set QueryCount=3 where Id in (" + ids.TrimEnd(',') + ")");
  114. function.WritePage("/TradeRecord/", "Id3.txt", startId);
  115. }
  116. db.SaveChanges();
  117. }
  118. tran.Commit();
  119. }
  120. catch (Exception ex)
  121. {
  122. tran.Rollback();
  123. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时执行助利宝交易额异常");
  124. }
  125. }
  126. db.Dispose();
  127. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时执行助利宝交易额日志");
  128. }
  129. public void StatTradeAmountTmp()
  130. {
  131. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  132. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时执行助利宝交易额日志");
  133. WebCMSEntities db = new WebCMSEntities();
  134. using (var tran = db.Database.BeginTransaction())
  135. {
  136. try
  137. {
  138. DataTable selfDt = OtherMySqlConn.dtable("select MerchantId,DATE_FORMAT(CreateDate,'%Y%m'),sum(TradeAmount) from TradeRecord where CreateDate>='2022-09-05 00:00:00' and MerchantId in (select MerchantId from HelpProfitMerIds) and SeoTitle='HelpProfit' group by MerchantId,DATE_FORMAT(CreateDate,'%Y%m') order by MerchantId,DATE_FORMAT(CreateDate,'%Y%m')");
  139. if (selfDt.Rows.Count > 0)
  140. {
  141. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "实时执行助利宝交易额日志");
  142. foreach (DataRow selfDr in selfDt.Rows)
  143. {
  144. int MerchantId = int.Parse(selfDr["MerchantId"].ToString());
  145. string TradeMonth = selfDr[1].ToString();
  146. decimal TradeAmount = decimal.Parse(selfDr[2].ToString());
  147. HelpProfitMerIds merIds = db.HelpProfitMerIds.FirstOrDefault(m => m.MerchantId == MerchantId) ?? new HelpProfitMerIds();
  148. HelpProfitAmountSummary profitStat = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == merIds.UserId && m.TradeMonth == TradeMonth);
  149. if (profitStat == null)
  150. {
  151. int Month = db.HelpProfitAmountSummary.Count(m => m.UserId == merIds.UserId && Convert.ToInt32(m.TradeMonth) <= Convert.ToInt32(TradeMonth));
  152. profitStat = db.HelpProfitAmountSummary.Add(new HelpProfitAmountSummary()
  153. {
  154. TradeMonth = TradeMonth,
  155. UserId = merIds.UserId,
  156. QueryCount = Month + 1,
  157. }).Entity;
  158. db.SaveChanges();
  159. }
  160. profitStat.TradeAmount += TradeAmount;
  161. }
  162. }
  163. db.SaveChanges();
  164. tran.Commit();
  165. }
  166. catch (Exception ex)
  167. {
  168. tran.Rollback();
  169. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时执行助利宝交易额2异常");
  170. }
  171. }
  172. db.Dispose();
  173. }
  174. // 统计创客商机台数
  175. public void StartUserTrade()
  176. {
  177. Thread th = new Thread(StartUserTradeDo);
  178. th.IsBackground = true;
  179. th.Start();
  180. }
  181. public void StartUserTradeDo()
  182. {
  183. while (true)
  184. {
  185. if (DateTime.Now.Hour >= 3)
  186. {
  187. StartUserTradeGo();
  188. }
  189. Thread.Sleep(30000);
  190. }
  191. }
  192. public void StartUserTradeGo()
  193. {
  194. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  195. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时统计助利宝创客交易额日志");
  196. WebCMSEntities db = new WebCMSEntities();
  197. using (var tran = db.Database.BeginTransaction())
  198. {
  199. try
  200. {
  201. bool op = true;
  202. while(op)
  203. {
  204. string startId = function.ReadInstance("/TradeRecord/HelpProfitMerchantForUserId.txt");
  205. if (string.IsNullOrEmpty(startId))
  206. {
  207. startId = "0";
  208. }
  209. DataTable idsDt = OtherMySqlConn.dtable("select Id from HelpProfitMerchantForUser where Id>=" + startId + " and Status=0 order by Id limit 50");
  210. if (idsDt.Rows.Count > 0)
  211. {
  212. string ids = "";
  213. foreach (DataRow idsDr in idsDt.Rows)
  214. {
  215. ids += idsDr["Id"].ToString() + ",";
  216. startId = idsDr["Id"].ToString();
  217. }
  218. DataTable selfDt = OtherMySqlConn.dtable("select UserId,DATE_FORMAT(CreateDate,'%Y%m'),count(Id) from HelpProfitMerchantForUser where Id in (" + ids.TrimEnd(',') + ") group by UserId,DATE_FORMAT(CreateDate,'%Y%m')");
  219. if (selfDt.Rows.Count > 0)
  220. {
  221. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "实时统计助利宝创客交易额日志");
  222. foreach (DataRow selfDr in selfDt.Rows)
  223. {
  224. int UserId = int.Parse(selfDr["UserId"].ToString());
  225. string TradeMonth = selfDr[1].ToString();
  226. int MerCount = int.Parse(selfDr[2].ToString());
  227. HelpProfitAmountSummary selfStat = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth);
  228. if (selfStat == null)
  229. {
  230. int CheckMonth = db.HelpProfitAmountSummary.Count(m => m.UserId == UserId && Convert.ToInt32(m.TradeMonth) <= Convert.ToInt32(TradeMonth));
  231. selfStat = db.HelpProfitAmountSummary.Add(new HelpProfitAmountSummary()
  232. {
  233. TradeMonth = TradeMonth,
  234. UserId = UserId,
  235. QueryCount = CheckMonth + 1,
  236. }).Entity;
  237. db.SaveChanges();
  238. }
  239. selfStat.MerCount += MerCount;
  240. int Month = selfStat.QueryCount;
  241. if(Month > 24)
  242. {
  243. Month = 24;
  244. }
  245. selfStat.MaxAmount += EveryMonthFixedVal()[Month] * MerCount;
  246. }
  247. OtherMySqlConn.op("update HelpProfitMerchantForUser set Status=1 where Id in (" + ids.TrimEnd(',') + ")");
  248. function.WritePage("/TradeRecord/", "HelpProfitMerchantForUserId.txt", startId);
  249. }
  250. db.SaveChanges();
  251. }
  252. else
  253. {
  254. op = false;
  255. }
  256. }
  257. tran.Commit();
  258. }
  259. catch (Exception ex)
  260. {
  261. tran.Rollback();
  262. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时统计助利宝创客交易额异常");
  263. }
  264. }
  265. db.Dispose();
  266. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时统计助利宝创客交易额日志");
  267. }
  268. //计算商户交易额是否入账
  269. private bool CheckAmount(WebCMSEntities db, int MerchantId, int UserId, string TradeMonth)
  270. {
  271. HelpProfitAmountSummary Summary = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth) ?? new HelpProfitAmountSummary();
  272. decimal MaxTradeAmount = Summary.MaxAmount; //当月最大交易总额
  273. decimal CheckAmount = 500000 < MaxTradeAmount * 0.3M ? 500000 : MaxTradeAmount * 0.3M;
  274. //当月单台交易额 <= 50万或当月最大交易总额的30%(取小值),则入账
  275. HelpProfitMerTradeMonthSummay MonthStat = db.HelpProfitMerTradeMonthSummay.FirstOrDefault(m => m.MerchantId == MerchantId && m.TradeMonth == TradeMonth) ?? new HelpProfitMerTradeMonthSummay();
  276. decimal SingleTradeAmount = MonthStat.TradeAmount;
  277. if (SingleTradeAmount < CheckAmount)
  278. {
  279. //当月总交易额不超过当月最大交易总额,则入账
  280. if (Summary.TradeAmount < MaxTradeAmount)
  281. {
  282. return true;
  283. }
  284. }
  285. return false;
  286. }
  287. //商户24个月,每月固定额度
  288. private Dictionary<int, decimal> EveryMonthFixedVal()
  289. {
  290. Dictionary<int, decimal> obj = new Dictionary<int, decimal>();
  291. obj.Add(0, 0M);
  292. obj.Add(1, 70000M);
  293. obj.Add(2, 60000M);
  294. obj.Add(3, 50000M);
  295. obj.Add(4, 40000M);
  296. obj.Add(5, 30000M);
  297. obj.Add(6, 30000M);
  298. obj.Add(7, 27000M);
  299. obj.Add(8, 25000M);
  300. obj.Add(9, 20000M);
  301. obj.Add(10, 17000M);
  302. obj.Add(11, 14000M);
  303. obj.Add(12, 14000M);
  304. obj.Add(13, 13000M);
  305. obj.Add(14, 12000M);
  306. obj.Add(15, 12000M);
  307. obj.Add(16, 10000M);
  308. obj.Add(17, 8000M);
  309. obj.Add(18, 7000M);
  310. obj.Add(19, 6000M);
  311. obj.Add(20, 5000M);
  312. obj.Add(21, 4000M);
  313. obj.Add(22, 3000M);
  314. obj.Add(23, 2000M);
  315. obj.Add(24, 1000M);
  316. return obj;
  317. }
  318. #region 每月重置最大交易总额
  319. public void ResetMaxTradeAmount()
  320. {
  321. Thread th = new Thread(ResetMaxTradeAmountDo);
  322. th.IsBackground = true;
  323. th.Start();
  324. }
  325. public void ResetMaxTradeAmountDo()
  326. {
  327. while (true)
  328. {
  329. if (DateTime.Now.Day == 1 && DateTime.Now.Hour > 0 && DateTime.Now.Hour < 3)
  330. {
  331. string TradeMonth = DateTime.Now.ToString("yyyyMM");
  332. ResetMaxTradeAmountGo(TradeMonth);
  333. }
  334. Thread.Sleep(30000);
  335. }
  336. }
  337. public void ResetMaxTradeAmountGo(string TradeMonth)
  338. {
  339. try
  340. {
  341. string CheckExist = function.ReadInstance("/HelpProfitAmountSummary/" + TradeMonth + ".txt");
  342. if(string.IsNullOrEmpty(CheckExist))
  343. {
  344. function.WritePage("/HelpProfitAmountSummary/", TradeMonth + ".txt", DateTime.Now.ToString());
  345. WebCMSEntities db = new WebCMSEntities();
  346. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  347. DataTable userlist = OtherMySqlConn.dtable("select DISTINCT UserId from HelpProfitAmountSummary order by UserId");
  348. // DataTable userlist = OtherMySqlConn.dtable("select DISTINCT UserId from HelpProfitAmountSummary where (TradeMonth='202209' or TradeMonth='202210') and UserId not in (select UserId from HelpProfitAmountSummary where TradeMonth='202211')");
  349. foreach (DataRow user in userlist.Rows)
  350. {
  351. int UserId = int.Parse(user["UserId"].ToString());
  352. int MonthCount = db.HelpProfitAmountSummary.Count(m => m.UserId == UserId) + 1;
  353. int Month = MonthCount;
  354. if(Month > 24)
  355. {
  356. Month = 24;
  357. }
  358. decimal MonthAmount1 = 0; //本月额度
  359. decimal MonthAmount2 = 0; //上月额度
  360. decimal MonthAmount3 = 0; //上上月额度
  361. if(Month > 0)
  362. {
  363. MonthAmount1 = EveryMonthFixedVal()[Month]; //上月额度
  364. }
  365. if(Month > 1)
  366. {
  367. MonthAmount2 = EveryMonthFixedVal()[Month - 1]; //上月额度
  368. }
  369. if(Month > 2)
  370. {
  371. MonthAmount3 = EveryMonthFixedVal()[Month - 2]; //上上月额度
  372. }
  373. List<int> MerCounts = new List<int>(); //近3月月台数,包含当月
  374. List<decimal> MaxTradeAmounts = new List<decimal>(); //近3月最大额度,包含当月
  375. int MerCount1 = 0; //本月台数
  376. int MerCount2 = 0; //上月台数
  377. int MerCount3 = 0; //上上月台数
  378. decimal PreMaxTradeAmount = 0; //上月最大额度
  379. decimal PreTradeAmount = 0; //上月创客交易额
  380. List<HelpProfitAmountSummary> Summarys = db.HelpProfitAmountSummary.Where(m => m.UserId == UserId && Convert.ToInt32(m.TradeMonth) <= Convert.ToInt32(TradeMonth)).OrderByDescending(m => m.TradeMonth).Take(3).ToList();
  381. foreach(HelpProfitAmountSummary Summary in Summarys)
  382. {
  383. MerCounts.Add(Summary.MerCount);
  384. MaxTradeAmounts.Add(Summary.MaxAmount);
  385. }
  386. if(MerCounts.Count > 0)
  387. {
  388. MerCount1 = MerCounts[0];
  389. }
  390. if(MerCounts.Count > 1)
  391. {
  392. MerCount2 = MerCounts[1];
  393. PreMaxTradeAmount = MaxTradeAmounts[1];
  394. string PreMonthString = DateTime.Parse(TradeMonth.Substring(0, 4) + "-" + TradeMonth.Substring(4, 2) + "-01").AddMonths(-1).ToString("yyyyMM");
  395. DataTable dt = OtherMySqlConn.dtable("SELECT SUM(TradeAmount) TradeAmount FROM HelpProfitMerTradeSummay WHERE MerchantId IN(SELECT MerchantId FROM HelpProfitMerIds WHERE UserId=" + UserId + ") AND TradeMonth=" + PreMonthString + "");
  396. if (dt.Rows.Count > 0)
  397. {
  398. PreTradeAmount = decimal.Parse(function.CheckNum(dt.Rows[0]["TradeAmount"].ToString()));
  399. }
  400. }
  401. if(MerCounts.Count > 2)
  402. {
  403. MerCount3 = MerCounts[2];
  404. }
  405. decimal MaxTradeAmount = MerCount1 * MonthAmount1 + MerCount2 * MonthAmount2 + MerCount3 * MonthAmount3; //当月最大交易总额
  406. MaxTradeAmount = PreMaxTradeAmount - PreTradeAmount + MaxTradeAmount; //上月最大额度-实际交易额+本月最大交易额
  407. HelpProfitAmountSummary selfStat = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth);
  408. if(selfStat == null)
  409. {
  410. selfStat = db.HelpProfitAmountSummary.Add(new HelpProfitAmountSummary()
  411. {
  412. UserId = UserId,
  413. TradeMonth = TradeMonth,
  414. QueryCount = MonthCount,
  415. }).Entity;
  416. db.SaveChanges();
  417. }
  418. selfStat.MaxAmount = MaxTradeAmount;
  419. }
  420. db.SaveChanges();
  421. db.Dispose();
  422. }
  423. }
  424. catch(Exception ex)
  425. {
  426. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "每月重置最大交易总额异常");
  427. }
  428. }
  429. #endregion
  430. public void StatTradeTmp()
  431. {
  432. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  433. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时执行助利宝交易额日志");
  434. WebCMSEntities db = new WebCMSEntities();
  435. using (var tran = db.Database.BeginTransaction())
  436. {
  437. try
  438. {
  439. DataTable idsDt = OtherMySqlConn.dtable("select Id from TradeRecord where Id>=4150000 and CreateDate>='2022-11-27 00:00:00' and CreateDate<'2022-11-28 00:00:00' and MerchantId in (select MerchantId from HelpProfitMerIds) and SeoTitle='HelpProfit' and QueryCount=3 and MerchantId in (select MerchantId from HelpProfitMerchantForUser where UserId in (144214,144213,144170,144046,143420,143294,142953,142861,142736,142642,142608,142545,142532,142484,142297,142263,141951,141878,141838,141814,141562,141469,141295,141239,141073,140952,140816,140470,140221,140220,139917,139815,139729,139639,139094,138877,138516,138173,138021,138014,137967,137870,137706,137361,136263,136181,135950,135524,135448,135373,135251,135224,135121,134915,134503,133783,133420,132996,132839,132726,132642,132488,132469,132234,131903,131845,131025,130767,130744,130334,130113,129947,129814,129111,128853,128758,128640,128513,128322,127634,127188,126802,126782,126620,126613,125981,125848,125778,125754,124875,124822,124344,123770,123747,123115,122986,121779,121749,121570,121404,121108,120998,120957,120776,120720,120663,120650,120604,110031,109906,109405,106581,105286,100934,99148,93049,91467,88519,88494,84401,80747,72018,69881,69195,68888,64167,63784,62252,60846,60561,60035,59740,59159,57366,56869,56182,56080,55049,54784,54517,52449,52265,51193,50886,49838,49145,48849,46655,46284,45892,41420,41200,40498,40282,40280,39109,38520,37033,36932,36488,35805,33055,32534,27524,24528,21108,18724,15600,15509,15506,11124,9367,7601,7487,6764,6267,4861,3885,3835,3015,1893,1797,1703,1195,1052,668,609,602,599,598,588,586,583,582,565,560,558,514,415,392,391,389,387,281,276,237,45,1))");
  440. if (idsDt.Rows.Count > 0)
  441. {
  442. string ids = "";
  443. foreach (DataRow idsDr in idsDt.Rows)
  444. {
  445. ids += idsDr["Id"].ToString() + ",";
  446. }
  447. DataTable selfDt = OtherMySqlConn.dtable("select MerchantId,DATE_FORMAT(CreateDate,'%Y%m%d'),sum(TradeAmount) from TradeRecord where Id in (" + ids.TrimEnd(',') + ") group by MerchantId,DATE_FORMAT(CreateDate,'%Y%m%d')");
  448. if (selfDt.Rows.Count > 0)
  449. {
  450. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "实时执行助利宝交易额日志");
  451. foreach (DataRow selfDr in selfDt.Rows)
  452. {
  453. int MerchantId = int.Parse(selfDr["MerchantId"].ToString());
  454. string TradeDate = selfDr[1].ToString();
  455. string TradeMonth = TradeDate.Substring(0, 6);
  456. decimal TradeAmount = decimal.Parse(selfDr[2].ToString());
  457. HelpProfitMerIds merIds = db.HelpProfitMerIds.FirstOrDefault(m => m.MerchantId == MerchantId) ?? new HelpProfitMerIds();
  458. bool Check = CheckAmount(db, MerchantId, merIds.UserId, TradeMonth);
  459. if (Check)
  460. {
  461. HelpProfitMerTradeSummay selfStat = db.HelpProfitMerTradeSummay.FirstOrDefault(m => m.MerchantId == MerchantId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate);
  462. if (selfStat == null)
  463. {
  464. selfStat = db.HelpProfitMerTradeSummay.Add(new HelpProfitMerTradeSummay()
  465. {
  466. TradeMonth = TradeMonth,
  467. TradeDate = TradeDate,
  468. MerchantId = MerchantId,
  469. }).Entity;
  470. db.SaveChanges();
  471. }
  472. decimal MoreAmount = TradeAmount * 0.01M;
  473. MoreAmount = decimal.Parse(function.CheckInt(MoreAmount.ToString().Split(".")[0]));
  474. selfStat.TradeAmount = TradeAmount + MoreAmount;
  475. }
  476. }
  477. }
  478. db.SaveChanges();
  479. }
  480. tran.Commit();
  481. }
  482. catch (Exception ex)
  483. {
  484. tran.Rollback();
  485. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时执行助利宝交易额异常");
  486. }
  487. }
  488. db.Dispose();
  489. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时执行助利宝交易额日志");
  490. }
  491. }
  492. }