ProfitService.cs 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489
  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.ProfitModels;
  9. namespace MySystem
  10. {
  11. public class ProfitService
  12. {
  13. public readonly static ProfitService Instance = new ProfitService();
  14. private ProfitService()
  15. { }
  16. // 统计交易额到RDS
  17. public void StartStat()
  18. {
  19. Thread th = new Thread(StartStatDo);
  20. th.IsBackground = true;
  21. th.Start();
  22. }
  23. public void StartStatDo()
  24. {
  25. while (true)
  26. {
  27. string content = RedisDbconn.Instance.RPop<string>("ProfitTradeAmountQueue");
  28. if(!string.IsNullOrEmpty(content))
  29. {
  30. StatTradeAmount(content);
  31. }
  32. else
  33. {
  34. Thread.Sleep(10000);
  35. }
  36. }
  37. }
  38. public void StatTradeAmount(string content)
  39. {
  40. WebCMSEntities db = new WebCMSEntities();
  41. PxcModels.WebCMSEntities maindb = new PxcModels.WebCMSEntities();
  42. try
  43. {
  44. JsonData selfDr = JsonMapper.ToObject(content);
  45. int UserId = int.Parse(selfDr["UserId"].ToString());
  46. PxcModels.Users user = maindb.Users.FirstOrDefault(m => m.Id == UserId) ?? new PxcModels.Users();
  47. string ParentNav = user.ParentNav;
  48. int BrandId = int.Parse(selfDr["BrandId"].ToString());
  49. int BankCardType = int.Parse(selfDr["BankCardType"].ToString());
  50. int QrPayFlag = int.Parse(selfDr["QrPayFlag"].ToString());
  51. int MerHelpFlag = int.Parse(selfDr["MerHelpFlag"].ToString());
  52. int Version = int.Parse(selfDr["Version"].ToString());
  53. int CapFlag = int.Parse(selfDr["CapFlag"].ToString());
  54. int VipFlag = int.Parse(selfDr["VipFlag"].ToString());
  55. int PayType = int.Parse(selfDr["PayType"].ToString());
  56. string TradeDate = selfDr["TradeDate"].ToString();
  57. decimal TradeAmount = decimal.Parse(selfDr["TradeAmount"].ToString());
  58. int TradeCount = int.Parse(selfDr["TradeCount"].ToString());
  59. string TradeMonth = TradeDate.Substring(0, 6);
  60. 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");
  61. if (selfStat == null)
  62. {
  63. selfStat = db.TradeDaySummary.Add(new TradeDaySummary()
  64. {
  65. UserId = UserId,
  66. TradeMonth = TradeMonth,
  67. TradeDate = TradeDate,
  68. BrandId = BrandId,
  69. QueryCount = QrPayFlag,
  70. VipFlag = VipFlag,
  71. PayType = PayType,
  72. SeoTitle = "self",
  73. }).Entity;
  74. db.SaveChanges();
  75. }
  76. if (BankCardType == 0)
  77. {
  78. if (Version == 1)
  79. {
  80. selfStat.ProfitDirectDebitTradeAmt += TradeAmount;
  81. if (CapFlag == 1)
  82. {
  83. selfStat.ProfitDirectDebitCapTradeAmt += TradeAmount;
  84. selfStat.ProfitDirectDebitCapNum += TradeCount;
  85. }
  86. }
  87. else if (MerHelpFlag == 1)
  88. {
  89. selfStat.HelpDirectDebitTradeAmt += TradeAmount;
  90. if (CapFlag == 1)
  91. {
  92. selfStat.HelpDirectDebitCapTradeAmt += TradeAmount;
  93. selfStat.HelpDirectDebitCapNum += TradeCount;
  94. }
  95. }
  96. else
  97. {
  98. selfStat.NotHelpDirectDebitTradeAmt += TradeAmount;
  99. if (CapFlag == 1)
  100. {
  101. selfStat.NotHelpDirectDebitCapTradeAmt += TradeAmount;
  102. selfStat.NotHelpDirectDebitCapNum += TradeCount;
  103. }
  104. }
  105. }
  106. else if (BankCardType != 0)
  107. {
  108. if (Version == 1)
  109. {
  110. selfStat.ProfitDirectTradeAmt += TradeAmount;
  111. }
  112. else if (MerHelpFlag == 1)
  113. {
  114. selfStat.HelpDirectTradeAmt += TradeAmount;
  115. }
  116. else
  117. {
  118. selfStat.NotHelpDirectTradeAmt += TradeAmount;
  119. }
  120. }
  121. ParentNav += "," + UserId + ",";
  122. if (!string.IsNullOrEmpty(ParentNav))
  123. {
  124. string[] ParentNavList = ParentNav.Trim(',').Replace(",,", ",").Split(',');
  125. foreach (string NavUserIdString in ParentNavList)
  126. {
  127. int NavUserId = int.Parse(NavUserIdString);
  128. 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");
  129. if (teamStat == null)
  130. {
  131. teamStat = db.TradeDaySummary.Add(new TradeDaySummary()
  132. {
  133. UserId = NavUserId,
  134. TradeMonth = TradeMonth,
  135. TradeDate = TradeDate,
  136. BrandId = BrandId,
  137. QueryCount = QrPayFlag,
  138. VipFlag = VipFlag,
  139. PayType = PayType,
  140. SeoTitle = "team",
  141. }).Entity;
  142. db.SaveChanges();
  143. }
  144. if (BankCardType == 0)
  145. {
  146. if (Version == 1)
  147. {
  148. teamStat.ProfitNonDirectDebitTradeAmt += TradeAmount;
  149. if (CapFlag == 1)
  150. {
  151. teamStat.ProfitDirectDebitCapTradeAmt += TradeAmount;
  152. teamStat.ProfitDirectDebitCapNum += TradeCount;
  153. }
  154. }
  155. else if (MerHelpFlag == 1)
  156. {
  157. teamStat.HelpNonDirectDebitTradeAmt += TradeAmount;
  158. if (CapFlag == 1)
  159. {
  160. teamStat.HelpDirectDebitCapTradeAmt += TradeAmount;
  161. teamStat.HelpDirectDebitCapNum += TradeCount;
  162. }
  163. }
  164. else
  165. {
  166. teamStat.NotHelpNonDirectDebitTradeAmt += TradeAmount;
  167. if (CapFlag == 1)
  168. {
  169. teamStat.NotHelpDirectDebitCapTradeAmt += TradeAmount;
  170. teamStat.NotHelpDirectDebitCapNum += TradeCount;
  171. }
  172. }
  173. }
  174. else if (BankCardType != 0)
  175. {
  176. if (Version == 1)
  177. {
  178. teamStat.ProfitNonDirectTradeAmt += TradeAmount;
  179. }
  180. else if (MerHelpFlag == 1)
  181. {
  182. teamStat.HelpNonDirectTradeAmt += TradeAmount;
  183. }
  184. else
  185. {
  186. teamStat.NotHelpNonDirectTradeAmt += TradeAmount;
  187. }
  188. }
  189. }
  190. }
  191. db.SaveChanges();
  192. }
  193. catch (Exception ex)
  194. {
  195. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "实时统计交易额日志RDSnew异常");
  196. }
  197. maindb.Dispose();
  198. db.Dispose();
  199. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "实时统计交易额日志RDSnew");
  200. }
  201. public void AddRds()
  202. {
  203. // AddTradeDaySummary(); //补TradeDaySummary数据
  204. // AddUserAccountRecord(); //补UserAccountRecord数据
  205. // AddProfitRecord(); //补ProfitRecord数据
  206. // AddSubsidyRecord(); //补SubsidyRecord数据
  207. AddRdsData("UserAccountRecord");
  208. AddRdsData("ProfitRecord");
  209. AddRdsData("SubsidyRecord");
  210. }
  211. public void AddRdsData(string TableName)
  212. {
  213. Thread th = new Thread(AddRdsDataDo);
  214. th.IsBackground = true;
  215. th.Start(TableName);
  216. }
  217. public void AddRdsDataDo(object sender)
  218. {
  219. string TableName = sender.ToString();
  220. while (true)
  221. {
  222. if(RedisDbconn.Instance.Get<string>(TableName + "ThreadStatus") == "1")
  223. {
  224. RdsDataDo(TableName);
  225. }
  226. else
  227. {
  228. Thread.Sleep(5000);
  229. }
  230. }
  231. }
  232. public void RdsDataDo(string TableName)
  233. {
  234. WebCMSEntities db = new WebCMSEntities();
  235. PxcModels.WebCMSEntities maindb = new PxcModels.WebCMSEntities();
  236. try
  237. {
  238. string sql = "";
  239. int startId = int.Parse(function.CheckInt(function.ReadInstance("/TradeRecord/" + TableName + "Id.txt")));
  240. DataTable dt = CustomerSqlConn.dtable("select * from " + TableName + " where Id>" + startId + " order by Id limit 100", AppConfig.Base.ProfitSqlConn);
  241. if(dt.Rows.Count > 0)
  242. {
  243. foreach(DataRow dr in dt.Rows)
  244. {
  245. string fields = "";
  246. string vals = "";
  247. foreach(DataColumn dc in dt.Columns)
  248. {
  249. fields += dc.ColumnName + ",";
  250. if(dc.DataType == typeof(DateTime))
  251. {
  252. string val = dr[dc.ColumnName].ToString();
  253. if(string.IsNullOrEmpty(val))
  254. {
  255. val = "NULL";
  256. }
  257. else
  258. {
  259. val = "'" + DateTime.Parse(val).ToString("yyyy-MM-dd HH:mm:ss") + "'";
  260. }
  261. vals = dr[dc.ColumnName].ToString() + ",";
  262. }
  263. if(dc.DataType == typeof(int) || dc.DataType == typeof(decimal))
  264. {
  265. vals = dr[dc.ColumnName].ToString() + ",";
  266. }
  267. else
  268. {
  269. vals = dr[dc.ColumnName].ToString() + ",";
  270. }
  271. }
  272. sql += "insert into (" + fields.TrimEnd(',') + ") values (" + vals.TrimEnd(',') + ");\n";
  273. startId = int.Parse(function.CheckInt(dr["Id"].ToString()));
  274. }
  275. CustomerSqlConn.op(sql, AppConfig.Base.ProfitSqlConn);
  276. function.WritePage("/TradeRecord/", TableName + "Id.txt", startId.ToString());
  277. }
  278. }
  279. catch (Exception ex)
  280. {
  281. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "补" + TableName + "数据异常");
  282. }
  283. maindb.Dispose();
  284. db.Dispose();
  285. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "补" + TableName + "数据");
  286. }
  287. // 补TradeDaySummary数据
  288. public void AddTradeDaySummary()
  289. {
  290. Thread th = new Thread(AddTradeDaySummaryDo);
  291. th.IsBackground = true;
  292. th.Start();
  293. }
  294. public void AddTradeDaySummaryDo()
  295. {
  296. while (true)
  297. {
  298. if(RedisDbconn.Instance.Get<string>("TradeDaySummaryThreadStatus") == "1")
  299. {
  300. TradeDaySummaryDo();
  301. }
  302. else
  303. {
  304. Thread.Sleep(1000);
  305. }
  306. }
  307. }
  308. public void TradeDaySummaryDo()
  309. {
  310. WebCMSEntities db = new WebCMSEntities();
  311. PxcModels.WebCMSEntities maindb = new PxcModels.WebCMSEntities();
  312. try
  313. {
  314. int startId = int.Parse(function.CheckInt(function.ReadInstance("/TradeRecord/TradeDaySummaryId.txt")));
  315. List<PxcModels.TradeDaySummary> list = maindb.TradeDaySummary.Where(m => m.Id > startId && m.Id <= 13509689).OrderBy(m => m.Id).Take(100).ToList();
  316. foreach(PxcModels.TradeDaySummary sub in list)
  317. {
  318. db.TradeDaySummary.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<TradeDaySummary>(Newtonsoft.Json.JsonConvert.SerializeObject(sub)));
  319. startId = sub.Id;
  320. }
  321. function.WritePage("/TradeRecord/", "TradeDaySummaryId.txt", startId.ToString());
  322. db.SaveChanges();
  323. }
  324. catch (Exception ex)
  325. {
  326. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "补TradeDaySummary数据异常");
  327. }
  328. maindb.Dispose();
  329. db.Dispose();
  330. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "补TradeDaySummary数据");
  331. }
  332. // 同步UserAccountRecord数据
  333. public void AddUserAccountRecord()
  334. {
  335. Thread th = new Thread(AddUserAccountRecordDo);
  336. th.IsBackground = true;
  337. th.Start();
  338. }
  339. public void AddUserAccountRecordDo()
  340. {
  341. while (true)
  342. {
  343. if(RedisDbconn.Instance.Get<string>("UserAccountRecordThreadStatus") == "1")
  344. {
  345. UserAccountRecordDo();
  346. }
  347. else
  348. {
  349. Thread.Sleep(1000);
  350. }
  351. }
  352. }
  353. public void UserAccountRecordDo()
  354. {
  355. WebCMSEntities db = new WebCMSEntities();
  356. PxcModels.WebCMSEntities maindb = new PxcModels.WebCMSEntities();
  357. try
  358. {
  359. int startId = int.Parse(function.CheckInt(function.ReadInstance("/TradeRecord/UserAccountRecordId.txt")));
  360. List<PxcModels.UserAccountRecord> list = maindb.UserAccountRecord.Where(m => m.Id > startId).OrderBy(m => m.Id).Take(100).ToList();
  361. foreach(PxcModels.UserAccountRecord sub in list)
  362. {
  363. db.UserAccountRecord.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<UserAccountRecord>(Newtonsoft.Json.JsonConvert.SerializeObject(sub)));
  364. startId = sub.Id;
  365. }
  366. function.WritePage("/TradeRecord/", "UserAccountRecordId.txt", startId.ToString());
  367. db.SaveChanges();
  368. }
  369. catch (Exception ex)
  370. {
  371. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "补UserAccountRecord数据异常");
  372. }
  373. maindb.Dispose();
  374. db.Dispose();
  375. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "补UserAccountRecord数据");
  376. }
  377. // 同步ProfitRecord数据
  378. public void AddProfitRecord()
  379. {
  380. Thread th = new Thread(AddProfitRecordDo);
  381. th.IsBackground = true;
  382. th.Start();
  383. }
  384. public void AddProfitRecordDo()
  385. {
  386. while (true)
  387. {
  388. if(RedisDbconn.Instance.Get<string>("ProfitRecordThreadStatus") == "1")
  389. {
  390. ProfitRecordDo();
  391. }
  392. else
  393. {
  394. Thread.Sleep(1000);
  395. }
  396. }
  397. }
  398. public void ProfitRecordDo()
  399. {
  400. WebCMSEntities db = new WebCMSEntities();
  401. PxcModels.WebCMSEntities maindb = new PxcModels.WebCMSEntities();
  402. try
  403. {
  404. int startId = int.Parse(function.CheckInt(function.ReadInstance("/TradeRecord/ProfitRecordId.txt")));
  405. List<PxcModels.ProfitRecord> list = maindb.ProfitRecord.Where(m => m.Id > startId).OrderBy(m => m.Id).Take(100).ToList();
  406. foreach(PxcModels.ProfitRecord sub in list)
  407. {
  408. db.ProfitRecord.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<ProfitRecord>(Newtonsoft.Json.JsonConvert.SerializeObject(sub)));
  409. startId = sub.Id;
  410. }
  411. function.WritePage("/TradeRecord/", "ProfitRecordId.txt", startId.ToString());
  412. db.SaveChanges();
  413. }
  414. catch (Exception ex)
  415. {
  416. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "补ProfitRecord数据异常");
  417. }
  418. maindb.Dispose();
  419. db.Dispose();
  420. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "补ProfitRecord数据");
  421. }
  422. // 同步SubsidyRecord数据
  423. public void AddSubsidyRecord()
  424. {
  425. Thread th = new Thread(AddSubsidyRecordDo);
  426. th.IsBackground = true;
  427. th.Start();
  428. }
  429. public void AddSubsidyRecordDo()
  430. {
  431. while (true)
  432. {
  433. if(RedisDbconn.Instance.Get<string>("SubsidyRecordThreadStatus") == "1")
  434. {
  435. SubsidyRecordDo();
  436. }
  437. else
  438. {
  439. Thread.Sleep(1000);
  440. }
  441. }
  442. }
  443. public void SubsidyRecordDo()
  444. {
  445. WebCMSEntities db = new WebCMSEntities();
  446. PxcModels.WebCMSEntities maindb = new PxcModels.WebCMSEntities();
  447. try
  448. {
  449. int startId = int.Parse(function.CheckInt(function.ReadInstance("/TradeRecord/SubsidyRecordId.txt")));
  450. List<PxcModels.SubsidyRecord> list = maindb.SubsidyRecord.Where(m => m.Id > startId).OrderBy(m => m.Id).Take(100).ToList();
  451. foreach(PxcModels.SubsidyRecord sub in list)
  452. {
  453. db.SubsidyRecord.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<SubsidyRecord>(Newtonsoft.Json.JsonConvert.SerializeObject(sub)));
  454. startId = sub.Id;
  455. }
  456. function.WritePage("/TradeRecord/", "SubsidyRecordId.txt", startId.ToString());
  457. db.SaveChanges();
  458. }
  459. catch (Exception ex)
  460. {
  461. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "补SubsidyRecord数据异常");
  462. }
  463. maindb.Dispose();
  464. db.Dispose();
  465. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "补SubsidyRecord数据");
  466. }
  467. }
  468. }