StatHelpProfitService.cs 49 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981
  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 = "30000000";
  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 StatTradeForHelpProfit(string month)
  131. {
  132. string connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  133. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时执行助利宝交易额日志");
  134. WebCMSEntities db = new WebCMSEntities();
  135. try
  136. {
  137. string startId = function.ReadInstance("/TradeRecord/Id3.txt");
  138. if (string.IsNullOrEmpty(startId))
  139. {
  140. startId = "30000000";
  141. }
  142. string start = month + "-01 00:00:00";
  143. string end = DateTime.Parse(start).AddMonths(1).ToString("yyyy-MM-dd HH:mm:ss");
  144. DataTable selfDt = CustomerSqlConn.dtable("select MerchantId,DATE_FORMAT(CreateDate,'%Y%m%d'),sum(TradeAmount) from TradeRecord where Id>=" + startId + " and ActStatus=1 and CreateDate>='" + start + "' and CreateDate<'" + end + "' and MerchantId in (select MerchantId from HelpProfitMerIds) and SeoTitle='HelpProfit' group by MerchantId,DATE_FORMAT(CreateDate,'%Y%m%d')", connstr);
  145. if (selfDt.Rows.Count > 0)
  146. {
  147. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "实时执行助利宝交易额日志");
  148. foreach (DataRow selfDr in selfDt.Rows)
  149. {
  150. int MerchantId = int.Parse(selfDr["MerchantId"].ToString());
  151. string TradeDate = selfDr[1].ToString();
  152. string TradeMonth = TradeDate.Substring(0, 6);
  153. decimal TradeAmount = decimal.Parse(selfDr[2].ToString());
  154. HelpProfitMerIds merIds = db.HelpProfitMerIds.FirstOrDefault(m => m.MerchantId == MerchantId) ?? new HelpProfitMerIds();
  155. bool Check = CheckAmount(db, MerchantId, merIds.UserId, TradeMonth);
  156. if (Check)
  157. {
  158. decimal MoreAmount = TradeAmount * 0.01M;
  159. int random = function.get_Random(0, 10000);
  160. // if(MoreAmount > 1 && random < 5000)
  161. // {
  162. MoreAmount = decimal.Parse(function.CheckInt(MoreAmount.ToString().Split(".")[0]));
  163. // }
  164. HelpProfitMerTradeSummay selfStat = db.HelpProfitMerTradeSummay.FirstOrDefault(m => m.MerchantId == MerchantId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate);
  165. if (selfStat == null)
  166. {
  167. selfStat = db.HelpProfitMerTradeSummay.Add(new HelpProfitMerTradeSummay()
  168. {
  169. TradeMonth = TradeMonth,
  170. TradeDate = TradeDate,
  171. MerchantId = MerchantId,
  172. }).Entity;
  173. db.SaveChanges();
  174. }
  175. selfStat.TradeAmount += TradeAmount + MoreAmount;
  176. HelpProfitMerTradeMonthSummay monthStat = db.HelpProfitMerTradeMonthSummay.FirstOrDefault(m => m.MerchantId == MerchantId && m.TradeMonth == TradeMonth);
  177. if (monthStat == null)
  178. {
  179. monthStat = db.HelpProfitMerTradeMonthSummay.Add(new HelpProfitMerTradeMonthSummay()
  180. {
  181. TradeMonth = TradeMonth,
  182. MerchantId = MerchantId,
  183. }).Entity;
  184. db.SaveChanges();
  185. }
  186. monthStat.TradeAmount += TradeAmount + MoreAmount;
  187. HelpProfitAmountSummary amountStat = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == merIds.UserId && m.TradeMonth == TradeMonth);
  188. if (amountStat == null)
  189. {
  190. amountStat = db.HelpProfitAmountSummary.Add(new HelpProfitAmountSummary()
  191. {
  192. TradeMonth = TradeMonth,
  193. UserId = merIds.UserId,
  194. }).Entity;
  195. db.SaveChanges();
  196. }
  197. if(amountStat.TradeAmount + TradeAmount + MoreAmount <= amountStat.MaxAmount) amountStat.TradeAmount += TradeAmount + MoreAmount;
  198. else amountStat.TradeAmount = amountStat.MaxAmount;
  199. StatTradeAmountEverDayForUser(db, merIds.UserId, TradeAmount + MoreAmount, TradeDate);
  200. }
  201. }
  202. function.WritePage("/TradeRecord/", "Id3.txt", startId);
  203. }
  204. db.SaveChanges();
  205. }
  206. catch (Exception ex)
  207. {
  208. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时执行助利宝交易额异常");
  209. }
  210. db.Dispose();
  211. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时执行助利宝交易额日志");
  212. }
  213. public void AddUserHelpProfit()
  214. {
  215. Thread th = new Thread(AddUserHelpProfitDo);
  216. th.IsBackground = true;
  217. th.Start();
  218. }
  219. public void AddUserHelpProfitDo()
  220. {
  221. while (true)
  222. {
  223. if (RedisDbconn.Instance.Get<string>("StatServerStatus") == "1")
  224. {
  225. AddUserHelpProfitGo();
  226. }
  227. Thread.Sleep(1000);
  228. }
  229. }
  230. public void AddUserHelpProfitGo()
  231. {
  232. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "补助利宝创客交易额日志");
  233. WebCMSEntities db = new WebCMSEntities();
  234. try
  235. {
  236. string startId = function.ReadInstance("/TradeRecord/HelpProfitMerTradeSummayId.txt");
  237. if (string.IsNullOrEmpty(startId))
  238. {
  239. startId = "414382";
  240. }
  241. DataTable selfDt = CustomerSqlConn.dtable("select * from HelpProfitMerTradeSummay where Id>" + startId + " and Id<=488029 and Status=0 order by Id limit 100", AppConfig.Base.SqlConn);
  242. if (selfDt.Rows.Count > 0)
  243. {
  244. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "补助利宝创客交易额日志");
  245. foreach (DataRow selfDr in selfDt.Rows)
  246. {
  247. startId = selfDr["Id"].ToString();
  248. int MerchantId = int.Parse(selfDr["MerchantId"].ToString());
  249. string TradeDate = selfDr["TradeDate"].ToString();
  250. string TradeMonth = selfDr["TradeMonth"].ToString();
  251. decimal TradeAmount = decimal.Parse(selfDr["TradeAmount"].ToString());
  252. HelpProfitMerIds merIds = db.HelpProfitMerIds.FirstOrDefault(m => m.MerchantId == MerchantId) ?? new HelpProfitMerIds();
  253. StatTradeAmountEverDayForUser(db, merIds.UserId, TradeAmount, TradeDate);
  254. CustomerSqlConn.op("update HelpProfitMerTradeSummay set Status=1 where Id=" + startId, AppConfig.Base.SqlConn);
  255. }
  256. function.WritePage("/TradeRecord/", "HelpProfitMerTradeSummayId.txt", startId);
  257. }
  258. db.SaveChanges();
  259. }
  260. catch (Exception ex)
  261. {
  262. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "补助利宝创客交易额异常");
  263. }
  264. db.Dispose();
  265. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "补助利宝创客交易额日志");
  266. }
  267. private void StatTradeAmountEverDayForUser(WebCMSEntities db, int UserId, decimal TradeAmount, string TradeDate)
  268. {
  269. Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  270. string ParentNav = user.ParentNav;
  271. string TradeMonth = TradeDate.Substring(0, 6);
  272. HelpProfitUserTradeSummay selfStat = db.HelpProfitUserTradeSummay.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.SeoTitle == "self");
  273. if (selfStat == null)
  274. {
  275. selfStat = db.HelpProfitUserTradeSummay.Add(new HelpProfitUserTradeSummay()
  276. {
  277. UserId = UserId,
  278. TradeMonth = TradeMonth,
  279. TradeDate = TradeDate,
  280. SeoTitle = "self",
  281. }).Entity;
  282. db.SaveChanges();
  283. }
  284. selfStat.TradeAmount += TradeAmount;
  285. ParentNav += "," + UserId + ",";
  286. if (!string.IsNullOrEmpty(ParentNav))
  287. {
  288. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  289. foreach (string NavUserIdString in ParentNavList)
  290. {
  291. int NavUserId = int.Parse(NavUserIdString);
  292. HelpProfitUserTradeSummay teamStat = db.HelpProfitUserTradeSummay.FirstOrDefault(m => m.UserId == NavUserId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate && m.SeoTitle == "team");
  293. if (teamStat == null)
  294. {
  295. teamStat = db.HelpProfitUserTradeSummay.Add(new HelpProfitUserTradeSummay()
  296. {
  297. UserId = NavUserId,
  298. TradeMonth = TradeMonth,
  299. TradeDate = TradeDate,
  300. SeoTitle = "team",
  301. }).Entity;
  302. db.SaveChanges();
  303. }
  304. teamStat.TradeAmount += TradeAmount;
  305. }
  306. }
  307. db.SaveChanges();
  308. }
  309. public void StatTradeAmountTmp()
  310. {
  311. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  312. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时执行助利宝交易额日志");
  313. WebCMSEntities db = new WebCMSEntities();
  314. using (var tran = db.Database.BeginTransaction())
  315. {
  316. try
  317. {
  318. 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')");
  319. if (selfDt.Rows.Count > 0)
  320. {
  321. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "实时执行助利宝交易额日志");
  322. foreach (DataRow selfDr in selfDt.Rows)
  323. {
  324. int MerchantId = int.Parse(selfDr["MerchantId"].ToString());
  325. string TradeMonth = selfDr[1].ToString();
  326. decimal TradeAmount = decimal.Parse(selfDr[2].ToString());
  327. HelpProfitMerIds merIds = db.HelpProfitMerIds.FirstOrDefault(m => m.MerchantId == MerchantId) ?? new HelpProfitMerIds();
  328. HelpProfitAmountSummary profitStat = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == merIds.UserId && m.TradeMonth == TradeMonth);
  329. if (profitStat == null)
  330. {
  331. int Month = db.HelpProfitAmountSummary.Count(m => m.UserId == merIds.UserId && Convert.ToInt32(m.TradeMonth) <= Convert.ToInt32(TradeMonth));
  332. profitStat = db.HelpProfitAmountSummary.Add(new HelpProfitAmountSummary()
  333. {
  334. TradeMonth = TradeMonth,
  335. UserId = merIds.UserId,
  336. QueryCount = Month + 1,
  337. }).Entity;
  338. db.SaveChanges();
  339. }
  340. profitStat.TradeAmount += TradeAmount;
  341. }
  342. }
  343. db.SaveChanges();
  344. tran.Commit();
  345. }
  346. catch (Exception ex)
  347. {
  348. tran.Rollback();
  349. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时执行助利宝交易额2异常");
  350. }
  351. }
  352. db.Dispose();
  353. }
  354. // 统计创客商机台数
  355. public void StartUserTrade()
  356. {
  357. Thread th = new Thread(StartUserTradeDo);
  358. th.IsBackground = true;
  359. th.Start();
  360. }
  361. public void StartUserTradeDo()
  362. {
  363. while (true)
  364. {
  365. if (RedisDbconn.Instance.Get<string>("StatServerStatus") == "1" && DateTime.Now.Hour >= 3)
  366. {
  367. StartUserTradeGo();
  368. }
  369. // Thread.Sleep(30000);
  370. }
  371. }
  372. public void StartUserTradeGo()
  373. {
  374. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  375. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时统计助利宝创客交易额日志");
  376. WebCMSEntities db = new WebCMSEntities();
  377. using (var tran = db.Database.BeginTransaction())
  378. {
  379. try
  380. {
  381. bool op = true;
  382. while(op)
  383. {
  384. string startId = function.ReadInstance("/TradeRecord/HelpProfitMerchantForUserId.txt");
  385. if (string.IsNullOrEmpty(startId))
  386. {
  387. startId = "0";
  388. }
  389. DataTable idsDt = OtherMySqlConn.dtable("select Id from HelpProfitMerchantForUser where Id>=" + startId + " and Status=0 order by Id limit 50");
  390. if (idsDt.Rows.Count > 0)
  391. {
  392. string ids = "";
  393. foreach (DataRow idsDr in idsDt.Rows)
  394. {
  395. ids += idsDr["Id"].ToString() + ",";
  396. startId = idsDr["Id"].ToString();
  397. }
  398. 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')");
  399. if (selfDt.Rows.Count > 0)
  400. {
  401. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "实时统计助利宝创客交易额日志");
  402. foreach (DataRow selfDr in selfDt.Rows)
  403. {
  404. int UserId = int.Parse(selfDr["UserId"].ToString());
  405. string TradeMonth = selfDr[1].ToString();
  406. int MerCount = int.Parse(selfDr[2].ToString());
  407. HelpProfitAmountSummary selfStat = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth);
  408. if (selfStat == null)
  409. {
  410. int CheckMonth = db.HelpProfitAmountSummary.Count(m => m.UserId == UserId && Convert.ToInt32(m.TradeMonth) <= Convert.ToInt32(TradeMonth));
  411. selfStat = db.HelpProfitAmountSummary.Add(new HelpProfitAmountSummary()
  412. {
  413. TradeMonth = TradeMonth,
  414. UserId = UserId,
  415. QueryCount = CheckMonth + 1,
  416. }).Entity;
  417. db.SaveChanges();
  418. }
  419. selfStat.MerCount += MerCount;
  420. int Month = selfStat.QueryCount;
  421. if(Month > 36)
  422. {
  423. Month = 36;
  424. }
  425. selfStat.MaxAmount += EveryMonthFixedVal()[Month] * MerCount;
  426. }
  427. OtherMySqlConn.op("update HelpProfitMerchantForUser set Status=1 where Id in (" + ids.TrimEnd(',') + ")");
  428. function.WritePage("/TradeRecord/", "HelpProfitMerchantForUserId.txt", startId);
  429. }
  430. db.SaveChanges();
  431. }
  432. else
  433. {
  434. op = false;
  435. }
  436. }
  437. tran.Commit();
  438. }
  439. catch (Exception ex)
  440. {
  441. tran.Rollback();
  442. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时统计助利宝创客交易额异常");
  443. }
  444. }
  445. db.Dispose();
  446. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时统计助利宝创客交易额日志");
  447. }
  448. //计算商户交易额是否入账
  449. private bool CheckAmount(WebCMSEntities db, int MerchantId, int UserId, string TradeMonth)
  450. {
  451. HelpProfitAmountSummary Summary = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth) ?? new HelpProfitAmountSummary();
  452. // ====================
  453. if(DateTime.Now >= DateTime.Parse("2023-02-01 00:00:00") && DateTime.Now < DateTime.Parse("2023-03-01 00:00:00"))
  454. {
  455. HelpProfitAmountSummary PreSummary = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == "202301") ?? new HelpProfitAmountSummary();
  456. if(PreSummary.TradeAmount > PreSummary.MaxAmount)
  457. {
  458. string conn = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  459. DataTable check = CustomerSqlConn.dtable("SELECT DISTINCT TradeDate FROM HelpProfitMerTradeSummay WHERE MerchantId IN(SELECT MerchantId FROM HelpProfitMerIds WHERE UserId=" + UserId + ") AND TradeMonth='202301'", conn);
  460. if(check.Rows.Count < 31)
  461. {
  462. decimal HelpAmount = 0; //当天总交易额
  463. 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);
  464. if(dt.Rows.Count > 0)
  465. {
  466. HelpAmount = decimal.Parse(function.CheckNum(dt.Rows[0]["TradeAmount"].ToString()));
  467. }
  468. decimal PreHelpAmount = 0; //上月当天总交易额
  469. 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);
  470. if(dt.Rows.Count > 0)
  471. {
  472. PreHelpAmount = decimal.Parse(function.CheckNum(dt.Rows[0]["TradeAmount"].ToString()));
  473. }
  474. if(PreHelpAmount > HelpAmount && PreHelpAmount > 0)
  475. {
  476. decimal FixedPercent = TmpEveryDayPercent()[DateTime.Now.Day];
  477. if(PreHelpAmount * FixedPercent > HelpAmount)
  478. {
  479. return true;
  480. }
  481. else
  482. {
  483. return false;
  484. }
  485. }
  486. }
  487. }
  488. }
  489. // ====================
  490. decimal MaxTradeAmount = Summary.MaxAmount; //当月最大交易总额
  491. decimal CheckAmount = 500000 < MaxTradeAmount * 0.3M ? 500000 : MaxTradeAmount * 0.3M;
  492. //当月单台交易额 <= 50万或当月最大交易总额的30%(取小值),则入账
  493. HelpProfitMerTradeMonthSummay MonthStat = db.HelpProfitMerTradeMonthSummay.FirstOrDefault(m => m.MerchantId == MerchantId && m.TradeMonth == TradeMonth) ?? new HelpProfitMerTradeMonthSummay();
  494. decimal SingleTradeAmount = MonthStat.TradeAmount;
  495. if (SingleTradeAmount < CheckAmount)
  496. {
  497. //当月总交易额不超过当月最大交易总额,则入账
  498. if (Summary.TradeAmount < MaxTradeAmount)
  499. {
  500. decimal EveryDayTradeAmount = MaxTradeAmount / function.get_Random(30, 35); //当月最大交易总额平均值
  501. string conn = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  502. decimal HelpAmount = 0; //当天总交易额
  503. 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);
  504. if(dt.Rows.Count > 0)
  505. {
  506. HelpAmount = decimal.Parse(function.CheckNum(dt.Rows[0]["TradeAmount"].ToString()));
  507. }
  508. //当天总交易额不超过当月最大交易总额平均值,则入账
  509. if(HelpAmount < EveryDayTradeAmount)
  510. {
  511. return true;
  512. }
  513. }
  514. }
  515. return false;
  516. }
  517. //商户24个月,每月固定额度
  518. private Dictionary<int, decimal> EveryMonthFixedVal()
  519. {
  520. Dictionary<int, decimal> obj = new Dictionary<int, decimal>();
  521. obj.Add(0, 0M);
  522. obj.Add(1, 70000M);
  523. obj.Add(2, 60000M);
  524. obj.Add(3, 50000M);
  525. obj.Add(4, 40000M);
  526. obj.Add(5, 30000M);
  527. obj.Add(6, 30000M);
  528. obj.Add(7, 27000M);
  529. obj.Add(8, 25000M);
  530. obj.Add(9, 20000M);
  531. obj.Add(10, 17000M);
  532. obj.Add(11, 14000M);
  533. obj.Add(12, 14000M);
  534. obj.Add(13, 13000M);
  535. obj.Add(14, 12000M);
  536. obj.Add(15, 12000M);
  537. obj.Add(16, 10000M);
  538. obj.Add(17, 8000M);
  539. obj.Add(18, 7000M);
  540. obj.Add(19, 6000M);
  541. obj.Add(20, 5000M);
  542. obj.Add(21, 4000M);
  543. obj.Add(22, 3000M);
  544. obj.Add(23, 2000M);
  545. obj.Add(24, 1000M);
  546. obj.Add(25, 900M);
  547. obj.Add(26, 800M);
  548. obj.Add(27, 700M);
  549. obj.Add(28, 600M);
  550. obj.Add(29, 500M);
  551. obj.Add(30, 400M);
  552. obj.Add(31, 300M);
  553. obj.Add(32, 200M);
  554. obj.Add(33, 150M);
  555. obj.Add(34, 100M);
  556. obj.Add(35, 50M);
  557. obj.Add(36, 0M);
  558. return obj;
  559. }
  560. private Dictionary<int, decimal> TmpEveryDayPercent()
  561. {
  562. Dictionary<int, decimal> obj = new Dictionary<int, decimal>();
  563. obj.Add(1, 0.90M);
  564. obj.Add(2, 0.85M);
  565. obj.Add(3, 0.83M);
  566. obj.Add(4, 0.79M);
  567. obj.Add(5, 0.82M);
  568. obj.Add(6, 0.75M);
  569. obj.Add(7, 0.73M);
  570. obj.Add(8, 0.7M);
  571. obj.Add(9, 0.68M);
  572. obj.Add(10, 0.69M);
  573. obj.Add(11, 0.63M);
  574. obj.Add(12, 0.66M);
  575. obj.Add(13, 0.62M);
  576. obj.Add(14, 0.65M);
  577. obj.Add(15, 0.6M);
  578. obj.Add(16, 0.58M);
  579. obj.Add(17, 0.56M);
  580. obj.Add(18, 0.53M);
  581. obj.Add(19, 0.55M);
  582. obj.Add(20, 0.51M);
  583. obj.Add(21, 0.53M);
  584. obj.Add(22, 0.52M);
  585. obj.Add(23, 0.54M);
  586. obj.Add(24, 0.52M);
  587. obj.Add(25, 0.51M);
  588. obj.Add(26, 0.53M);
  589. obj.Add(27, 0.51M);
  590. obj.Add(28, 0.5M);
  591. return obj;
  592. }
  593. #region 每月重置最大交易总额
  594. public void ResetMaxTradeAmount()
  595. {
  596. Thread th = new Thread(ResetMaxTradeAmountDo);
  597. th.IsBackground = true;
  598. th.Start();
  599. }
  600. public void ResetMaxTradeAmountDo()
  601. {
  602. while (true)
  603. {
  604. if (DateTime.Now.Day == 1 && DateTime.Now.Hour > 0 && DateTime.Now.Hour < 3 && DateTime.Now < DateTime.Parse("2025-10-02 00:00:00"))
  605. {
  606. string TradeMonth = DateTime.Now.ToString("yyyyMM");
  607. ResetMaxTradeAmountGo(TradeMonth);
  608. }
  609. Thread.Sleep(30000);
  610. }
  611. }
  612. public void ResetMaxTradeAmountGo(string TradeMonth)
  613. {
  614. try
  615. {
  616. string CheckExist = function.ReadInstance("/HelpProfitAmountSummary/" + TradeMonth + ".txt");
  617. if(string.IsNullOrEmpty(CheckExist))
  618. {
  619. function.WritePage("/HelpProfitAmountSummary/", TradeMonth + ".txt", DateTime.Now.ToString());
  620. WebCMSEntities db = new WebCMSEntities();
  621. string connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  622. DataTable userlist = CustomerSqlConn.dtable("select DISTINCT UserId from HelpProfitAmountSummary order by UserId", connstr);
  623. // 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')");
  624. foreach (DataRow user in userlist.Rows)
  625. {
  626. int UserId = int.Parse(user["UserId"].ToString());
  627. int MonthCount = db.HelpProfitAmountSummary.Count(m => m.UserId == UserId) + 1;
  628. int Month = MonthCount;
  629. // List<int> MerCounts = new List<int>(); //每月台数,包含当月
  630. // List<decimal> MaxTradeAmounts = new List<decimal>(); //每月最大固定额度
  631. // List<HelpProfitAmountSummary> Summarys = db.HelpProfitAmountSummary.Where(m => m.UserId == UserId && Convert.ToInt32(m.TradeMonth) <= Convert.ToInt32(TradeMonth)).OrderByDescending(m => m.TradeMonth).Take(36).ToList();
  632. // int MonthNum = 0;
  633. // foreach(HelpProfitAmountSummary Summary in Summarys)
  634. // {
  635. // MonthNum += 1;
  636. // MerCounts.Add(Summary.MerCount);
  637. // MaxTradeAmounts.Add(EveryMonthFixedVal()[MonthNum]);
  638. // }
  639. // decimal MaxTradeAmount = 0;
  640. // for (int i = 0; i < MerCounts.Count; i++)
  641. // {
  642. // MaxTradeAmount += MerCounts[i] * MaxTradeAmounts[i];
  643. // }
  644. // HelpProfitAmountSummary selfStat = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth);
  645. // if(selfStat == null)
  646. // {
  647. // selfStat = db.HelpProfitAmountSummary.Add(new HelpProfitAmountSummary()
  648. // {
  649. // UserId = UserId,
  650. // TradeMonth = TradeMonth,
  651. // QueryCount = MonthCount,
  652. // }).Entity;
  653. // db.SaveChanges();
  654. // }
  655. // selfStat.MaxAmount = MaxTradeAmount;
  656. // function.WriteLog("update HelpProfitAmountSummary set MaxAmount=" + MaxTradeAmount + " where UserId=" + UserId + " and TradeMonth='" + TradeMonth + "';", "重置助利宝最大交易额");
  657. HelpProfitAmountSummary rootStat = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == "202501");
  658. if(rootStat != null)
  659. {
  660. decimal amt = rootStat.MaxAmount / 9;
  661. decimal min = amt * 0.98M;
  662. decimal max = amt * 1.02M;
  663. amt = function.get_Random((int)min, (int)max);
  664. HelpProfitAmountSummary selfStat = db.HelpProfitAmountSummary.FirstOrDefault(m => m.UserId == UserId && m.TradeMonth == TradeMonth);
  665. if(selfStat == null)
  666. {
  667. selfStat = db.HelpProfitAmountSummary.Add(new HelpProfitAmountSummary()
  668. {
  669. UserId = UserId,
  670. TradeMonth = TradeMonth,
  671. QueryCount = MonthCount,
  672. }).Entity;
  673. db.SaveChanges();
  674. }
  675. if(TradeMonth == "202510")
  676. {
  677. selfStat.MaxAmount = amt;
  678. }
  679. else
  680. {
  681. selfStat.MaxAmount = rootStat.MaxAmount - amt * (int.Parse(TradeMonth.Substring(4,2)) - 1);
  682. if(specialUserIds().Contains(UserId))
  683. {
  684. selfStat.MaxAmount -= amt * 3;
  685. }
  686. function.WriteLog(UserId + ":" + selfStat.MaxAmount, "助利宝交易核对");
  687. }
  688. }
  689. }
  690. db.SaveChanges();
  691. db.Dispose();
  692. StatTradeForHelpProfit(DateTime.Now.AddMonths(-1).ToString("yyyy-MM"));
  693. }
  694. }
  695. catch(Exception ex)
  696. {
  697. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "每月重置最大交易总额异常");
  698. }
  699. }
  700. public List<int> specialUserIds()
  701. {
  702. List<int> ids = new List<int>();
  703. ids.Add(52449);
  704. ids.Add(130487);
  705. ids.Add(145084);
  706. ids.Add(139917);
  707. ids.Add(141951);
  708. ids.Add(130199);
  709. ids.Add(121872);
  710. ids.Add(140323);
  711. ids.Add(106581);
  712. ids.Add(142087);
  713. ids.Add(129460);
  714. ids.Add(142608);
  715. ids.Add(131025);
  716. ids.Add(56080);
  717. ids.Add(63784);
  718. ids.Add(126659);
  719. ids.Add(142297);
  720. ids.Add(137361);
  721. ids.Add(120800);
  722. ids.Add(56358);
  723. ids.Add(56182);
  724. ids.Add(598);
  725. ids.Add(4861);
  726. ids.Add(48849);
  727. ids.Add(127188);
  728. ids.Add(132213);
  729. ids.Add(127381);
  730. ids.Add(49145);
  731. ids.Add(57366);
  732. ids.Add(139127);
  733. ids.Add(124344);
  734. ids.Add(499);
  735. ids.Add(145842);
  736. ids.Add(132469);
  737. ids.Add(15509);
  738. ids.Add(125981);
  739. ids.Add(1195);
  740. ids.Add(128513);
  741. ids.Add(24528);
  742. ids.Add(49838);
  743. ids.Add(142263);
  744. ids.Add(582);
  745. ids.Add(218);
  746. ids.Add(120604);
  747. ids.Add(121302);
  748. ids.Add(90080);
  749. ids.Add(4910);
  750. ids.Add(1703);
  751. ids.Add(145225);
  752. ids.Add(51193);
  753. ids.Add(592);
  754. ids.Add(146209);
  755. ids.Add(6764);
  756. ids.Add(1);
  757. ids.Add(144213);
  758. ids.Add(4331);
  759. ids.Add(6845);
  760. ids.Add(145832);
  761. ids.Add(609);
  762. ids.Add(140406);
  763. ids.Add(712);
  764. ids.Add(11154);
  765. ids.Add(125848);
  766. ids.Add(33055);
  767. ids.Add(1052);
  768. ids.Add(9);
  769. ids.Add(135524);
  770. ids.Add(142545);
  771. ids.Add(126101);
  772. ids.Add(109405);
  773. ids.Add(586);
  774. ids.Add(139909);
  775. ids.Add(120814);
  776. ids.Add(138446);
  777. ids.Add(144590);
  778. ids.Add(4328);
  779. ids.Add(130591);
  780. ids.Add(105286);
  781. ids.Add(138440);
  782. ids.Add(71852);
  783. ids.Add(59740);
  784. ids.Add(391);
  785. ids.Add(447);
  786. ids.Add(588);
  787. ids.Add(15506);
  788. ids.Add(88494);
  789. ids.Add(120957);
  790. ids.Add(415);
  791. ids.Add(140221);
  792. ids.Add(515);
  793. ids.Add(583);
  794. ids.Add(564);
  795. ids.Add(139742);
  796. ids.Add(7601);
  797. ids.Add(45892);
  798. ids.Add(129947);
  799. ids.Add(602);
  800. ids.Add(132996);
  801. ids.Add(120663);
  802. ids.Add(145452);
  803. ids.Add(60846);
  804. ids.Add(128447);
  805. ids.Add(140816);
  806. ids.Add(130334);
  807. ids.Add(12031);
  808. ids.Add(50886);
  809. ids.Add(72018);
  810. ids.Add(129010);
  811. ids.Add(3015);
  812. ids.Add(668);
  813. ids.Add(387);
  814. ids.Add(276);
  815. ids.Add(127023);
  816. ids.Add(132234);
  817. ids.Add(142642);
  818. ids.Add(514);
  819. ids.Add(281);
  820. ids.Add(134988);
  821. ids.Add(138014);
  822. ids.Add(2927);
  823. ids.Add(121108);
  824. ids.Add(100934);
  825. ids.Add(129111);
  826. ids.Add(145689);
  827. ids.Add(125754);
  828. ids.Add(141878);
  829. ids.Add(62252);
  830. ids.Add(130767);
  831. ids.Add(102753);
  832. ids.Add(130113);
  833. ids.Add(35805);
  834. ids.Add(141469);
  835. ids.Add(140220);
  836. ids.Add(129814);
  837. ids.Add(134503);
  838. ids.Add(144170);
  839. ids.Add(91582);
  840. ids.Add(109497);
  841. ids.Add(128322);
  842. ids.Add(122986);
  843. ids.Add(11124);
  844. ids.Add(156689);
  845. ids.Add(140952);
  846. ids.Add(125485);
  847. ids.Add(133420);
  848. ids.Add(93049);
  849. ids.Add(41420);
  850. ids.Add(141913);
  851. ids.Add(120745);
  852. ids.Add(45);
  853. ids.Add(69195);
  854. ids.Add(136181);
  855. ids.Add(149224);
  856. ids.Add(15600);
  857. ids.Add(125223);
  858. ids.Add(138877);
  859. ids.Add(135121);
  860. ids.Add(6267);
  861. ids.Add(144320);
  862. ids.Add(132488);
  863. ids.Add(135434);
  864. ids.Add(141426);
  865. ids.Add(142953);
  866. ids.Add(147153);
  867. ids.Add(560);
  868. ids.Add(144029);
  869. ids.Add(6898);
  870. ids.Add(36932);
  871. ids.Add(1797);
  872. ids.Add(221);
  873. ids.Add(99148);
  874. ids.Add(40282);
  875. ids.Add(132642);
  876. ids.Add(40498);
  877. ids.Add(128853);
  878. return ids;
  879. }
  880. #endregion
  881. public void StatTradeTmp()
  882. {
  883. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  884. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "实时执行助利宝交易额日志");
  885. WebCMSEntities db = new WebCMSEntities();
  886. using (var tran = db.Database.BeginTransaction())
  887. {
  888. try
  889. {
  890. 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))");
  891. if (idsDt.Rows.Count > 0)
  892. {
  893. string ids = "";
  894. foreach (DataRow idsDr in idsDt.Rows)
  895. {
  896. ids += idsDr["Id"].ToString() + ",";
  897. }
  898. 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')");
  899. if (selfDt.Rows.Count > 0)
  900. {
  901. function.WriteLog("统计人数:" + selfDt.Rows.Count + "\n\n", "实时执行助利宝交易额日志");
  902. foreach (DataRow selfDr in selfDt.Rows)
  903. {
  904. int MerchantId = int.Parse(selfDr["MerchantId"].ToString());
  905. string TradeDate = selfDr[1].ToString();
  906. string TradeMonth = TradeDate.Substring(0, 6);
  907. decimal TradeAmount = decimal.Parse(selfDr[2].ToString());
  908. HelpProfitMerIds merIds = db.HelpProfitMerIds.FirstOrDefault(m => m.MerchantId == MerchantId) ?? new HelpProfitMerIds();
  909. bool Check = CheckAmount(db, MerchantId, merIds.UserId, TradeMonth);
  910. if (Check)
  911. {
  912. HelpProfitMerTradeSummay selfStat = db.HelpProfitMerTradeSummay.FirstOrDefault(m => m.MerchantId == MerchantId && m.TradeMonth == TradeMonth && m.TradeDate == TradeDate);
  913. if (selfStat == null)
  914. {
  915. selfStat = db.HelpProfitMerTradeSummay.Add(new HelpProfitMerTradeSummay()
  916. {
  917. TradeMonth = TradeMonth,
  918. TradeDate = TradeDate,
  919. MerchantId = MerchantId,
  920. }).Entity;
  921. db.SaveChanges();
  922. }
  923. decimal MoreAmount = TradeAmount * 0.01M;
  924. MoreAmount = decimal.Parse(function.CheckInt(MoreAmount.ToString().Split(".")[0]));
  925. selfStat.TradeAmount = TradeAmount + MoreAmount;
  926. }
  927. }
  928. }
  929. db.SaveChanges();
  930. }
  931. tran.Commit();
  932. }
  933. catch (Exception ex)
  934. {
  935. tran.Rollback();
  936. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时执行助利宝交易额异常");
  937. }
  938. }
  939. db.Dispose();
  940. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时执行助利宝交易额日志");
  941. }
  942. }
  943. }