AddRecordService.cs 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  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 AddRecordService
  12. {
  13. public readonly static AddRecordService Instance = new AddRecordService();
  14. private AddRecordService()
  15. { }
  16. //分表字段集合
  17. private Dictionary<string, string> FieldDic = new Dictionary<string, string>()
  18. {
  19. {"TradeRecord", "Id,Sort,QueryCount,Status,Version,CreateDate,UpdateDate,CreateMan,UpdateMan,SeoTitle,SeoKeyword,SeoDescription,MerUserId,TopUserId,Remark,BrandId,DirectFlag,CapFlag,QrPayFlag,BankCardType,TradeAmount,TradeSerialNo,ClearDate,TradeDate,SnNo,MerBuddyType,HelpMonthCount,MerHelpFlag,MerNo,MerchantId,UserId,RecordNo,ParentNav,PayType,VipFlag,ActStatus"},
  20. {"UserAccountRecord", "Id,Sort,QueryCount,Status,Version,CreateDate,UpdateDate,CreateMan,UpdateMan,SeoTitle,SeoKeyword,SeoDescription,TransRecordNo,Remark,AfterBalanceAmount,BeforeBalanceAmount,AfterFreezeAmount,BeforeFreezeAmount,AfterTotalAmount,BeforeTotalAmount,ChangeAmount,ProductType,ChangeType,UserId,Kind"},
  21. {"SpBindRecord", "Id,Sort,QueryCount,Status,CreateDate,UpdateDate,SeoTitle,SeoKeyword,SeoDescription,ChannelSerial,UpdateTime,CreateTime,Remark,MerNewSnNo,ProductType,MerStatus,MerOperateType,MerOperateDate,MerSnNo,MerName,AgentName,MerNo,Field5,Field4,Field3,Field2,Field1"},
  22. {"SpMerchants", "Id,Sort,QueryCount,Status,CreateDate,UpdateDate,SeoTitle,SeoKeyword,SeoDescription,AgentNo,SnNo,UpdateTime,CreateTime,Remark,City,Province,ProductType,MerStatus,MerAuditDate,MerRegDate,MerIdcardNo,MerMobile,MerRealName,AgentName,MerName,MerNo,Field5,Field4,Field3,Field2,Field1"},
  23. {"SpActivateRecord", "Id,Sort,QueryCount,Status,CreateDate,UpdateDate,SeoTitle,SeoKeyword,SeoDescription,ProductType,AgentNo,Remark,BizEnterName,BizEnterNo,MerIdcardNo,MerRealName,ActivateDate,ActivateStatus,AssessMonthCount,AssessMonth,MerRegDate,SnNo,MerMobile,MerName,MerNo,ChannelSerial,Field5,Field4,Field3,Field2,Field1"},
  24. {"SpTradeRecord", "Id,Sort,QueryCount,Status,CreateDate,UpdateDate,SeoTitle,SeoKeyword,SeoDescription,ChannelSerial,AgentNo,ProductType,Remark,SettleMethod,SettleFee,BankCardNo,ReceiptType,IsStoreCashier,DigAmt,DigAmtFlag,MerMobile,DeviceType,TradeSnNo,BankCardType,SerEntryMode,TradeType,TradeTime,TradeDate,ErrorMsg,ErrorCode,TradeStatus,DiscountRateFlag,BankAuthCode,TradeReferNo,TradeAmount,MerName,MerNo,TradeSerialNo,Field5,Field4,Field3,Field2,Field1"},
  25. };
  26. //交易记录队列
  27. public void StartTradeRecord()
  28. {
  29. Thread th = new Thread(StartTradeRecordDo);
  30. th.IsBackground = true;
  31. th.Start();
  32. }
  33. public void StartTradeRecordDo()
  34. {
  35. while (true)
  36. {
  37. string content = RedisDbconn.Instance.RPop<string>("AddTradeRecordQueue");
  38. if(!string.IsNullOrEmpty(content))
  39. {
  40. string[] datalist = content.Split(new string[]{ "#cut#" }, StringSplitOptions.None);
  41. AddData(datalist[0], datalist[1], "TradeRecord");
  42. }
  43. else
  44. {
  45. Thread.Sleep(10000);
  46. }
  47. }
  48. }
  49. //收支明细队列
  50. public void StartUserAccountRecord()
  51. {
  52. Thread th = new Thread(StartUserAccountRecordDo);
  53. th.IsBackground = true;
  54. th.Start();
  55. }
  56. public void StartUserAccountRecordDo()
  57. {
  58. while (true)
  59. {
  60. string content = RedisDbconn.Instance.RPop<string>("AddUserAccountRecordQueue");
  61. if(!string.IsNullOrEmpty(content))
  62. {
  63. string[] datalist = content.Split(new string[]{ "#cut#" }, StringSplitOptions.None);
  64. AddData(datalist[0], datalist[1], "UserAccountRecord");
  65. }
  66. else
  67. {
  68. Thread.Sleep(10000);
  69. }
  70. }
  71. }
  72. //SP绑定记录队列
  73. public void StartSpBindRecord()
  74. {
  75. Thread th = new Thread(StartSpBindRecordDo);
  76. th.IsBackground = true;
  77. th.Start();
  78. }
  79. public void StartSpBindRecordDo()
  80. {
  81. while (true)
  82. {
  83. string content = RedisDbconn.Instance.RPop<string>("AddSpBindRecordQueue");
  84. if(!string.IsNullOrEmpty(content))
  85. {
  86. string[] datalist = content.Split(new string[]{ "#cut#" }, StringSplitOptions.None);
  87. AddData(datalist[0], datalist[1], "SpBindRecord");
  88. }
  89. else
  90. {
  91. Thread.Sleep(10000);
  92. }
  93. }
  94. }
  95. //SP商户信息队列
  96. public void StartSpMerchants()
  97. {
  98. Thread th = new Thread(StartSpMerchantsDo);
  99. th.IsBackground = true;
  100. th.Start();
  101. }
  102. public void StartSpMerchantsDo()
  103. {
  104. while (true)
  105. {
  106. string content = RedisDbconn.Instance.RPop<string>("AddSpMerchantsQueue");
  107. if(!string.IsNullOrEmpty(content))
  108. {
  109. string[] datalist = content.Split(new string[]{ "#cut#" }, StringSplitOptions.None);
  110. AddData(datalist[0], datalist[1], "SpMerchants");
  111. }
  112. else
  113. {
  114. Thread.Sleep(10000);
  115. }
  116. }
  117. }
  118. //SP激活押金队列
  119. public void StartSpActivateRecord()
  120. {
  121. Thread th = new Thread(StartSpActivateRecordDo);
  122. th.IsBackground = true;
  123. th.Start();
  124. }
  125. public void StartSpActivateRecordDo()
  126. {
  127. while (true)
  128. {
  129. string content = RedisDbconn.Instance.RPop<string>("AddSpActivateRecordQueue");
  130. if(!string.IsNullOrEmpty(content))
  131. {
  132. string[] datalist = content.Split(new string[]{ "#cut#" }, StringSplitOptions.None);
  133. AddData(datalist[0], datalist[1], "SpActivateRecord");
  134. }
  135. else
  136. {
  137. Thread.Sleep(10000);
  138. }
  139. }
  140. }
  141. //SP交易记录队列
  142. public void StartSpTradeRecord()
  143. {
  144. Thread th = new Thread(StartSpTradeRecordDo);
  145. th.IsBackground = true;
  146. th.Start();
  147. }
  148. public void StartSpTradeRecordDo()
  149. {
  150. while (true)
  151. {
  152. string content = RedisDbconn.Instance.RPop<string>("AddSpTradeRecordQueue");
  153. if(!string.IsNullOrEmpty(content))
  154. {
  155. string[] datalist = content.Split(new string[]{ "#cut#" }, StringSplitOptions.None);
  156. AddData(datalist[0], datalist[1], "SpTradeRecord");
  157. }
  158. else
  159. {
  160. Thread.Sleep(10000);
  161. }
  162. }
  163. }
  164. //添加表数据
  165. public void AddData(string content, string date, string table)
  166. {
  167. try
  168. {
  169. if(string.IsNullOrEmpty(RedisDbconn.Instance.Get<string>(table + date)))
  170. {
  171. CustomerSqlConn.op(AppConfig.Base.CreatePosMerchantTradeSummay.Replace("#DateTime#", date), AppConfig.Base.StatSqlConn);
  172. RedisDbconn.Instance.Set(table + date, "1");
  173. int sec = 3600 * 25;
  174. if(date.Length == 6)
  175. {
  176. sec = 3600 * 24 * 35;
  177. }
  178. RedisDbconn.Instance.SetExpire(table + date, sec);
  179. Thread.Sleep(2000);
  180. }
  181. JsonData selfDr = JsonMapper.ToObject(content);
  182. string fields = FieldDic[table];
  183. string val = "";
  184. foreach(string field in fields.Split(','))
  185. {
  186. Type t = selfDr[field].GetType();
  187. if(t == typeof(int) || t == typeof(decimal))
  188. {
  189. val += selfDr[field].ToString() + ",";
  190. }
  191. else
  192. {
  193. val += "'" + selfDr[field].ToString() + "',";
  194. }
  195. }
  196. string sql = "INSERT INTO " + table + date + " (" + fields + ") VALUES (" + val.TrimEnd(',') + ")";
  197. CustomerSqlConn.op(sql, AppConfig.Base.StatSqlConn);
  198. }
  199. catch (Exception ex)
  200. {
  201. function.WriteLog(DateTime.Now.ToString() + "\n" + ex.ToString(), "添加记录RDS异常");
  202. }
  203. function.WriteLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "\n\n", "添加记录RDS");
  204. }
  205. }
  206. }