StatHelpProfitService.cs 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679
  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 (RedisDbconn.Instance.Get<string>("StatServerStatus") == "1" && 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 ActStatus=1 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. StatTradeAmountEverDayForUser(db, merIds.UserId, TradeAmount + MoreAmount, TradeDate);
  112. }
  113. }
  114. OtherMySqlConn.op("update TradeRecord set QueryCount=3 where Id in (" + ids.TrimEnd(',') + ")");
  115. function.WritePage("/TradeRecord/", "Id3.txt", startId);
  116. }
  117. db.SaveChanges();
  118. }
  119. tran.Commit();
  120. }
  121. catch (Exception ex)
  122. {
  123. tran.Rollback();
  124. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时执行助利宝交易额异常");
  125. }
  126. }
  127. db.Dispose();
  128. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时执行助利宝交易额日志");
  129. }
  130. public void AddUserHelpProfit()
  131. {
  132. Thread th = new Thread(AddUserHelpProfitDo);
  133. th.IsBackground = true;
  134. th.Start();
  135. }
  136. public void AddUserHelpProfitDo()
  137. {
  138. while (true)
  139. {
  140. if (RedisDbconn.Instance.Get<string>("StatServerStatus") == "1")
  141. {
  142. AddUserHelpProfitGo();
  143. }
  144. Thread.Sleep(1000);
  145. }
  146. }
  147. public void AddUserHelpProfitGo()
  148. {
  149. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "补助利宝创客交易额日志");
  150. WebCMSEntities db = new WebCMSEntities();
  151. try
  152. {
  153. string startId = function.ReadInstance("/TradeRecord/HelpProfitMerTradeSummayId.txt");
  154. if (string.IsNullOrEmpty(startId))
  155. {
  156. startId = "414382";
  157. }
  158. DataTable selfDt = CustomerSqlConn.dtable("select * from HelpProfitMerTradeSummay where Id>" + startId + " and Id<=488029 and Status=0 order by Id limit 100", AppConfig.Base.SqlConn);
  159. if (selfDt.Rows.Count > 0)
  160. {
  161. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "补助利宝创客交易额日志");
  162. foreach (DataRow selfDr in selfDt.Rows)
  163. {
  164. startId = selfDr["Id"].ToString();
  165. int MerchantId = int.Parse(selfDr["MerchantId"].ToString());
  166. string TradeDate = selfDr["TradeDate"].ToString();
  167. string TradeMonth = selfDr["TradeMonth"].ToString();
  168. decimal TradeAmount = decimal.Parse(selfDr["TradeAmount"].ToString());
  169. HelpProfitMerIds merIds = db.HelpProfitMerIds.FirstOrDefault(m => m.MerchantId == MerchantId) ?? new HelpProfitMerIds();
  170. StatTradeAmountEverDayForUser(db, merIds.UserId, TradeAmount, TradeDate);
  171. CustomerSqlConn.op("update HelpProfitMerTradeSummay set Status=1 where Id=" + startId, AppConfig.Base.SqlConn);
  172. }
  173. function.WritePage("/TradeRecord/", "HelpProfitMerTradeSummayId.txt", startId);
  174. }
  175. db.SaveChanges();
  176. }
  177. catch (Exception ex)
  178. {
  179. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "补助利宝创客交易额异常");
  180. }
  181. db.Dispose();
  182. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "补助利宝创客交易额日志");
  183. }
  184. private void StatTradeAmountEverDayForUser(WebCMSEntities db, int UserId, decimal TradeAmount, string TradeDate)
  185. {
  186. Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  187. string ParentNav = user.ParentNav;
  188. string TradeMonth = TradeDate.Substring(0, 6);
  189. HelpProfitUserTradeSummay selfStat = db.HelpProfitUserTradeSummay.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.SeoTitle == "self");
  190. if (selfStat == null)
  191. {
  192. selfStat = db.HelpProfitUserTradeSummay.Add(new HelpProfitUserTradeSummay()
  193. {
  194. UserId = UserId,
  195. TradeMonth = TradeMonth,
  196. TradeDate = TradeDate,
  197. SeoTitle = "self",
  198. }).Entity;
  199. db.SaveChanges();
  200. }
  201. selfStat.TradeAmount += TradeAmount;
  202. ParentNav += "," + UserId + ",";
  203. if (!string.IsNullOrEmpty(ParentNav))
  204. {
  205. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  206. foreach (string NavUserIdString in ParentNavList)
  207. {
  208. int NavUserId = int.Parse(NavUserIdString);
  209. HelpProfitUserTradeSummay teamStat = db.HelpProfitUserTradeSummay.FirstOrDefault(m => m.UserId == NavUserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.SeoTitle == "team");
  210. if (teamStat == null)
  211. {
  212. teamStat = db.HelpProfitUserTradeSummay.Add(new HelpProfitUserTradeSummay()
  213. {
  214. UserId = NavUserId,
  215. TradeMonth = TradeMonth,
  216. TradeDate = TradeDate,
  217. SeoTitle = "team",
  218. }).Entity;
  219. db.SaveChanges();
  220. }
  221. teamStat.TradeAmount += TradeAmount;
  222. }
  223. }
  224. db.SaveChanges();
  225. }
  226. public void StatTradeAmountTmp()
  227. {
  228. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  229. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时执行助利宝交易额日志");
  230. WebCMSEntities db = new WebCMSEntities();
  231. using (var tran = db.Database.BeginTransaction())
  232. {
  233. try
  234. {
  235. 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')");
  236. if (selfDt.Rows.Count > 0)
  237. {
  238. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "实时执行助利宝交易额日志");
  239. foreach (DataRow selfDr in selfDt.Rows)
  240. {
  241. int MerchantId = int.Parse(selfDr["MerchantId"].ToString());
  242. string TradeMonth = selfDr[1].ToString();
  243. decimal TradeAmount = decimal.Parse(selfDr[2].ToString());
  244. HelpProfitMerIds merIds = db.HelpProfitMerIds.FirstOrDefault(m => m.MerchantId == MerchantId) ?? new HelpProfitMerIds();
  245. HelpProfitAmountSummary profitStat = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == merIds.UserId && m.TradeMonth == TradeMonth);
  246. if (profitStat == null)
  247. {
  248. int Month = db.HelpProfitAmountSummary.Count(m => m.UserId == merIds.UserId && Convert.ToInt32(m.TradeMonth) <= Convert.ToInt32(TradeMonth));
  249. profitStat = db.HelpProfitAmountSummary.Add(new HelpProfitAmountSummary()
  250. {
  251. TradeMonth = TradeMonth,
  252. UserId = merIds.UserId,
  253. QueryCount = Month + 1,
  254. }).Entity;
  255. db.SaveChanges();
  256. }
  257. profitStat.TradeAmount += TradeAmount;
  258. }
  259. }
  260. db.SaveChanges();
  261. tran.Commit();
  262. }
  263. catch (Exception ex)
  264. {
  265. tran.Rollback();
  266. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时执行助利宝交易额2异常");
  267. }
  268. }
  269. db.Dispose();
  270. }
  271. // 统计创客商机台数
  272. public void StartUserTrade()
  273. {
  274. Thread th = new Thread(StartUserTradeDo);
  275. th.IsBackground = true;
  276. th.Start();
  277. }
  278. public void StartUserTradeDo()
  279. {
  280. while (true)
  281. {
  282. if (RedisDbconn.Instance.Get<string>("StatServerStatus") == "1" && DateTime.Now.Hour >= 3)
  283. {
  284. StartUserTradeGo();
  285. }
  286. Thread.Sleep(30000);
  287. }
  288. }
  289. public void StartUserTradeGo()
  290. {
  291. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  292. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时统计助利宝创客交易额日志");
  293. WebCMSEntities db = new WebCMSEntities();
  294. using (var tran = db.Database.BeginTransaction())
  295. {
  296. try
  297. {
  298. bool op = true;
  299. while(op)
  300. {
  301. string startId = function.ReadInstance("/TradeRecord/HelpProfitMerchantForUserId.txt");
  302. if (string.IsNullOrEmpty(startId))
  303. {
  304. startId = "0";
  305. }
  306. DataTable idsDt = OtherMySqlConn.dtable("select Id from HelpProfitMerchantForUser where Id>=" + startId + " and Status=0 order by Id limit 50");
  307. if (idsDt.Rows.Count > 0)
  308. {
  309. string ids = "";
  310. foreach (DataRow idsDr in idsDt.Rows)
  311. {
  312. ids += idsDr["Id"].ToString() + ",";
  313. startId = idsDr["Id"].ToString();
  314. }
  315. 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')");
  316. if (selfDt.Rows.Count > 0)
  317. {
  318. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "实时统计助利宝创客交易额日志");
  319. foreach (DataRow selfDr in selfDt.Rows)
  320. {
  321. int UserId = int.Parse(selfDr["UserId"].ToString());
  322. string TradeMonth = selfDr[1].ToString();
  323. int MerCount = int.Parse(selfDr[2].ToString());
  324. HelpProfitAmountSummary selfStat = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth);
  325. if (selfStat == null)
  326. {
  327. int CheckMonth = db.HelpProfitAmountSummary.Count(m => m.UserId == UserId && Convert.ToInt32(m.TradeMonth) <= Convert.ToInt32(TradeMonth));
  328. selfStat = db.HelpProfitAmountSummary.Add(new HelpProfitAmountSummary()
  329. {
  330. TradeMonth = TradeMonth,
  331. UserId = UserId,
  332. QueryCount = CheckMonth + 1,
  333. }).Entity;
  334. db.SaveChanges();
  335. }
  336. selfStat.MerCount += MerCount;
  337. int Month = selfStat.QueryCount;
  338. if(Month > 36)
  339. {
  340. Month = 36;
  341. }
  342. selfStat.MaxAmount += EveryMonthFixedVal()[Month] * MerCount;
  343. }
  344. OtherMySqlConn.op("update HelpProfitMerchantForUser set Status=1 where Id in (" + ids.TrimEnd(',') + ")");
  345. function.WritePage("/TradeRecord/", "HelpProfitMerchantForUserId.txt", startId);
  346. }
  347. db.SaveChanges();
  348. }
  349. else
  350. {
  351. op = false;
  352. }
  353. }
  354. tran.Commit();
  355. }
  356. catch (Exception ex)
  357. {
  358. tran.Rollback();
  359. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时统计助利宝创客交易额异常");
  360. }
  361. }
  362. db.Dispose();
  363. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时统计助利宝创客交易额日志");
  364. }
  365. //计算商户交易额是否入账
  366. private bool CheckAmount(WebCMSEntities db, int MerchantId, int UserId, string TradeMonth)
  367. {
  368. HelpProfitAmountSummary Summary = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth) ?? new HelpProfitAmountSummary();
  369. // ====================
  370. if(DateTime.Now >= DateTime.Parse("2023-02-01 00:00:00") && DateTime.Now < DateTime.Parse("2023-03-01 00:00:00"))
  371. {
  372. HelpProfitAmountSummary PreSummary = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == "202301") ?? new HelpProfitAmountSummary();
  373. if(PreSummary.TradeAmount > PreSummary.MaxAmount)
  374. {
  375. string conn = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  376. DataTable check = CustomerSqlConn.dtable("SELECT DISTINCT TradeDate FROM HelpProfitMerTradeSummay WHERE MerchantId IN(SELECT MerchantId FROM HelpProfitMerIds WHERE UserId=" + UserId + ") AND TradeMonth='202301'", conn);
  377. if(check.Rows.Count < 31)
  378. {
  379. decimal HelpAmount = 0; //当天总交易额
  380. DataTable dt = CustomerSqlConn.dtable("SELECT SUM(TradeAmount) TradeAmount FROM HelpProfitMerTradeSummay WHERE MerchantId IN(SELECT MerchantId FROM HelpProfitMerIds WHERE UserId=" + UserId + ") AND TradeDate='" + DateTime.Now.ToString("yyyyMMdd") + "'", conn);
  381. if(dt.Rows.Count > 0)
  382. {
  383. HelpAmount = decimal.Parse(function.CheckNum(dt.Rows[0]["TradeAmount"].ToString()));
  384. }
  385. decimal PreHelpAmount = 0; //上月当天总交易额
  386. dt = CustomerSqlConn.dtable("SELECT SUM(TradeAmount) TradeAmount FROM HelpProfitMerTradeSummay WHERE MerchantId IN(SELECT MerchantId FROM HelpProfitMerIds WHERE UserId=" + UserId + ") AND TradeDate='" + DateTime.Now.AddMonths(-1).ToString("yyyyMMdd") + "'", conn);
  387. if(dt.Rows.Count > 0)
  388. {
  389. PreHelpAmount = decimal.Parse(function.CheckNum(dt.Rows[0]["TradeAmount"].ToString()));
  390. }
  391. if(PreHelpAmount > HelpAmount && PreHelpAmount > 0)
  392. {
  393. decimal FixedPercent = TmpEveryDayPercent()[DateTime.Now.Day];
  394. if(PreHelpAmount * FixedPercent > HelpAmount)
  395. {
  396. return true;
  397. }
  398. else
  399. {
  400. return false;
  401. }
  402. }
  403. }
  404. }
  405. }
  406. // ====================
  407. decimal MaxTradeAmount = Summary.MaxAmount; //当月最大交易总额
  408. decimal CheckAmount = 500000 < MaxTradeAmount * 0.3M ? 500000 : MaxTradeAmount * 0.3M;
  409. //当月单台交易额 <= 50万或当月最大交易总额的30%(取小值),则入账
  410. HelpProfitMerTradeMonthSummay MonthStat = db.HelpProfitMerTradeMonthSummay.FirstOrDefault(m => m.MerchantId == MerchantId && m.TradeMonth == TradeMonth) ?? new HelpProfitMerTradeMonthSummay();
  411. decimal SingleTradeAmount = MonthStat.TradeAmount;
  412. if (SingleTradeAmount < CheckAmount)
  413. {
  414. //当月总交易额不超过当月最大交易总额,则入账
  415. if (Summary.TradeAmount < MaxTradeAmount)
  416. {
  417. decimal EveryDayTradeAmount = MaxTradeAmount / function.get_Random(30, 35); //当月最大交易总额平均值
  418. string conn = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  419. decimal HelpAmount = 0; //当天总交易额
  420. DataTable dt = CustomerSqlConn.dtable("SELECT SUM(TradeAmount) TradeAmount FROM HelpProfitMerTradeSummay WHERE MerchantId IN(SELECT MerchantId FROM HelpProfitMerIds WHERE UserId=" + UserId + ") AND TradeDate='" + DateTime.Now.ToString("yyyyMMdd") + "'", conn);
  421. if(dt.Rows.Count > 0)
  422. {
  423. HelpAmount = decimal.Parse(function.CheckNum(dt.Rows[0]["TradeAmount"].ToString()));
  424. }
  425. //当天总交易额不超过当月最大交易总额平均值,则入账
  426. if(HelpAmount < EveryDayTradeAmount)
  427. {
  428. return true;
  429. }
  430. }
  431. }
  432. return false;
  433. }
  434. //商户24个月,每月固定额度
  435. private Dictionary<int, decimal> EveryMonthFixedVal()
  436. {
  437. Dictionary<int, decimal> obj = new Dictionary<int, decimal>();
  438. obj.Add(0, 0M);
  439. obj.Add(1, 70000M);
  440. obj.Add(2, 60000M);
  441. obj.Add(3, 50000M);
  442. obj.Add(4, 40000M);
  443. obj.Add(5, 30000M);
  444. obj.Add(6, 30000M);
  445. obj.Add(7, 27000M);
  446. obj.Add(8, 25000M);
  447. obj.Add(9, 20000M);
  448. obj.Add(10, 17000M);
  449. obj.Add(11, 14000M);
  450. obj.Add(12, 14000M);
  451. obj.Add(13, 13000M);
  452. obj.Add(14, 12000M);
  453. obj.Add(15, 12000M);
  454. obj.Add(16, 10000M);
  455. obj.Add(17, 8000M);
  456. obj.Add(18, 7000M);
  457. obj.Add(19, 6000M);
  458. obj.Add(20, 5000M);
  459. obj.Add(21, 4000M);
  460. obj.Add(22, 3000M);
  461. obj.Add(23, 2000M);
  462. obj.Add(24, 1000M);
  463. obj.Add(25, 900M);
  464. obj.Add(26, 800M);
  465. obj.Add(27, 700M);
  466. obj.Add(28, 600M);
  467. obj.Add(29, 500M);
  468. obj.Add(30, 400M);
  469. obj.Add(31, 300M);
  470. obj.Add(32, 200M);
  471. obj.Add(33, 150M);
  472. obj.Add(34, 100M);
  473. obj.Add(35, 50M);
  474. obj.Add(36, 0M);
  475. return obj;
  476. }
  477. private Dictionary<int, decimal> TmpEveryDayPercent()
  478. {
  479. Dictionary<int, decimal> obj = new Dictionary<int, decimal>();
  480. obj.Add(1, 0.90M);
  481. obj.Add(2, 0.85M);
  482. obj.Add(3, 0.83M);
  483. obj.Add(4, 0.79M);
  484. obj.Add(5, 0.82M);
  485. obj.Add(6, 0.75M);
  486. obj.Add(7, 0.73M);
  487. obj.Add(8, 0.7M);
  488. obj.Add(9, 0.68M);
  489. obj.Add(10, 0.69M);
  490. obj.Add(11, 0.63M);
  491. obj.Add(12, 0.66M);
  492. obj.Add(13, 0.62M);
  493. obj.Add(14, 0.65M);
  494. obj.Add(15, 0.6M);
  495. obj.Add(16, 0.58M);
  496. obj.Add(17, 0.56M);
  497. obj.Add(18, 0.53M);
  498. obj.Add(19, 0.55M);
  499. obj.Add(20, 0.51M);
  500. obj.Add(21, 0.53M);
  501. obj.Add(22, 0.52M);
  502. obj.Add(23, 0.54M);
  503. obj.Add(24, 0.52M);
  504. obj.Add(25, 0.51M);
  505. obj.Add(26, 0.53M);
  506. obj.Add(27, 0.51M);
  507. obj.Add(28, 0.5M);
  508. return obj;
  509. }
  510. #region 每月重置最大交易总额
  511. public void ResetMaxTradeAmount()
  512. {
  513. Thread th = new Thread(ResetMaxTradeAmountDo);
  514. th.IsBackground = true;
  515. th.Start();
  516. }
  517. public void ResetMaxTradeAmountDo()
  518. {
  519. while (true)
  520. {
  521. if (DateTime.Now.Day == 1 && DateTime.Now.Hour > 0 && DateTime.Now.Hour < 3)
  522. {
  523. string TradeMonth = DateTime.Now.ToString("yyyyMM");
  524. ResetMaxTradeAmountGo(TradeMonth);
  525. }
  526. Thread.Sleep(30000);
  527. }
  528. }
  529. public void ResetMaxTradeAmountGo(string TradeMonth)
  530. {
  531. try
  532. {
  533. string CheckExist = function.ReadInstance("/HelpProfitAmountSummary/" + TradeMonth + ".txt");
  534. if(string.IsNullOrEmpty(CheckExist))
  535. {
  536. function.WritePage("/HelpProfitAmountSummary/", TradeMonth + ".txt", DateTime.Now.ToString());
  537. WebCMSEntities db = new WebCMSEntities();
  538. string connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  539. DataTable userlist = CustomerSqlConn.dtable("select DISTINCT UserId from HelpProfitAmountSummary order by UserId", connstr);
  540. // 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')");
  541. foreach (DataRow user in userlist.Rows)
  542. {
  543. int UserId = int.Parse(user["UserId"].ToString());
  544. int MonthCount = db.HelpProfitAmountSummary.Count(m => m.UserId == UserId) + 1;
  545. int Month = MonthCount;
  546. List<int> MerCounts = new List<int>(); //每月台数,包含当月
  547. List<decimal> MaxTradeAmounts = new List<decimal>(); //每月最大固定额度
  548. List<HelpProfitAmountSummary> Summarys = db.HelpProfitAmountSummary.Where(m => m.UserId == UserId && Convert.ToInt32(m.TradeMonth) <= Convert.ToInt32(TradeMonth)).OrderByDescending(m => m.TradeMonth).Take(36).ToList();
  549. int MonthNum = 0;
  550. foreach(HelpProfitAmountSummary Summary in Summarys)
  551. {
  552. MonthNum += 1;
  553. MerCounts.Add(Summary.MerCount);
  554. MaxTradeAmounts.Add(EveryMonthFixedVal()[MonthNum]);
  555. }
  556. decimal MaxTradeAmount = 0;
  557. for (int i = 0; i < MerCounts.Count; i++)
  558. {
  559. MaxTradeAmount += MerCounts[i] * MaxTradeAmounts[i];
  560. }
  561. HelpProfitAmountSummary selfStat = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth);
  562. if(selfStat == null)
  563. {
  564. selfStat = db.HelpProfitAmountSummary.Add(new HelpProfitAmountSummary()
  565. {
  566. UserId = UserId,
  567. TradeMonth = TradeMonth,
  568. QueryCount = MonthCount,
  569. }).Entity;
  570. db.SaveChanges();
  571. }
  572. selfStat.MaxAmount = MaxTradeAmount;
  573. // function.WriteLog("update HelpProfitAmountSummary set MaxAmount=" + MaxTradeAmount + " where UserId=" + UserId + " and TradeMonth='" + TradeMonth + "';", "重置助利宝最大交易额");
  574. }
  575. db.SaveChanges();
  576. db.Dispose();
  577. }
  578. }
  579. catch(Exception ex)
  580. {
  581. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "每月重置最大交易总额异常");
  582. }
  583. }
  584. #endregion
  585. public void StatTradeTmp()
  586. {
  587. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  588. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时执行助利宝交易额日志");
  589. WebCMSEntities db = new WebCMSEntities();
  590. using (var tran = db.Database.BeginTransaction())
  591. {
  592. try
  593. {
  594. 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))");
  595. if (idsDt.Rows.Count > 0)
  596. {
  597. string ids = "";
  598. foreach (DataRow idsDr in idsDt.Rows)
  599. {
  600. ids += idsDr["Id"].ToString() + ",";
  601. }
  602. 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')");
  603. if (selfDt.Rows.Count > 0)
  604. {
  605. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "实时执行助利宝交易额日志");
  606. foreach (DataRow selfDr in selfDt.Rows)
  607. {
  608. int MerchantId = int.Parse(selfDr["MerchantId"].ToString());
  609. string TradeDate = selfDr[1].ToString();
  610. string TradeMonth = TradeDate.Substring(0, 6);
  611. decimal TradeAmount = decimal.Parse(selfDr[2].ToString());
  612. HelpProfitMerIds merIds = db.HelpProfitMerIds.FirstOrDefault(m => m.MerchantId == MerchantId) ?? new HelpProfitMerIds();
  613. bool Check = CheckAmount(db, MerchantId, merIds.UserId, TradeMonth);
  614. if (Check)
  615. {
  616. HelpProfitMerTradeSummay selfStat = db.HelpProfitMerTradeSummay.FirstOrDefault(m => m.MerchantId == MerchantId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate);
  617. if (selfStat == null)
  618. {
  619. selfStat = db.HelpProfitMerTradeSummay.Add(new HelpProfitMerTradeSummay()
  620. {
  621. TradeMonth = TradeMonth,
  622. TradeDate = TradeDate,
  623. MerchantId = MerchantId,
  624. }).Entity;
  625. db.SaveChanges();
  626. }
  627. decimal MoreAmount = TradeAmount * 0.01M;
  628. MoreAmount = decimal.Parse(function.CheckInt(MoreAmount.ToString().Split(".")[0]));
  629. selfStat.TradeAmount = TradeAmount + MoreAmount;
  630. }
  631. }
  632. }
  633. db.SaveChanges();
  634. }
  635. tran.Commit();
  636. }
  637. catch (Exception ex)
  638. {
  639. tran.Rollback();
  640. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时执行助利宝交易额异常");
  641. }
  642. }
  643. db.Dispose();
  644. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时执行助利宝交易额日志");
  645. }
  646. }
  647. }