Fcbjpk10.cs 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using MC.ORM;
  6. using CP.Common;
  7. using MySql.Data.MySqlClient;
  8. namespace CP.Model
  9. {
  10. #region model
  11. /// <summary>
  12. /// 北京PK10
  13. /// </summary>
  14. [TableName("fcbjpk10"), PrimaryKey("id")]
  15. public class Fcbjpk10Info
  16. {
  17. /// <summary>
  18. /// 自动编号
  19. /// </summary>
  20. public int id { get; set; }
  21. /// <summary>
  22. /// 期号
  23. /// </summary>
  24. public int qi { get; set; }
  25. /// <summary>
  26. /// 号码一
  27. /// </summary>
  28. public int n1 { get; set; }
  29. /// <summary>
  30. /// 号码二
  31. /// </summary>
  32. public int n2 { get; set; }
  33. /// <summary>
  34. /// 号码三
  35. /// </summary>
  36. public int n3 { get; set; }
  37. public int n4 { get; set; }
  38. public int n5 { get; set; }
  39. public int n6 { get; set; }
  40. public int n7 { get; set; }
  41. public int n8 { get; set; }
  42. public int n9 { get; set; }
  43. public int n10 { get; set; }
  44. /// <summary>
  45. /// 开奖号字串
  46. /// 01,02,03,04,05
  47. /// </summary>
  48. public string opencode { get; set; }
  49. /// <summary>
  50. /// 和值
  51. /// </summary>
  52. [Ignore]
  53. public int hz { get; set; }
  54. /// <summary>
  55. /// 跨度
  56. /// </summary>
  57. [Ignore]
  58. public int kd { get; set; }
  59. /// <summary>
  60. /// 开奖时间
  61. /// </summary>
  62. public DateTime date { get; set; }
  63. /// <summary>
  64. /// 数据入库时间
  65. /// </summary>
  66. public DateTime addtime { get; set; }
  67. /// <summary>
  68. /// 是否有错误标记 0:无 1:有
  69. /// </summary>
  70. public int iserror { set; get; }
  71. /// <summary>
  72. /// 是否有异常 0:无异常 1:有异常 2:人工已处理无异常
  73. /// </summary>
  74. public int isexception { set; get; }
  75. /// <summary>
  76. /// 来源 0:mongo 1:后台手工
  77. /// </summary>
  78. public int origin { set; get; }
  79. [Ignore]
  80. public int rank { get; set; }
  81. }
  82. #endregion
  83. #region 遗漏统计
  84. /// <summary>
  85. /// 北京pk10 号码遗漏模型
  86. /// </summary>
  87. public class Fcbjpk10NumMissInfo
  88. {
  89. /// <summary>
  90. /// 名称
  91. /// </summary>
  92. public string name { get; set; }
  93. /// <summary>
  94. /// 第一位
  95. /// </summary>
  96. public int[] n1w { get; set; }
  97. /// <summary>
  98. /// 第二位
  99. /// </summary>
  100. public int[] n2w { get; set; }
  101. /// <summary>
  102. /// 第三位
  103. /// </summary>
  104. public int[] n3w { get; set; }
  105. }
  106. /// <summary>
  107. /// 第n位走势图遗漏模型
  108. /// </summary>
  109. public class Fcbjpk10DnwMissInfo
  110. {
  111. /// <summary>
  112. /// 名称
  113. /// </summary>
  114. public string name { get; set; }
  115. /// <summary>
  116. /// 号码
  117. /// </summary>
  118. public int[] hm { get; set; }
  119. /// <summary>
  120. /// 大小
  121. /// </summary>
  122. public int[] dx { get; set; }
  123. /// <summary>
  124. /// 奇偶
  125. /// </summary>
  126. public int[] jo { get; set; }
  127. /// <summary>
  128. /// 质合
  129. /// </summary>
  130. public int[] zh { get; set; }
  131. /// <summary>
  132. /// 012路
  133. /// </summary>
  134. public int[] _012 { get; set; }
  135. }
  136. /// <summary>
  137. /// 奇偶走势图遗漏模型
  138. /// </summary>
  139. public class Fcbjpk10JoMissInfo
  140. {
  141. /// <summary>
  142. /// 名称
  143. /// </summary>
  144. public string name { get; set; }
  145. public int[] jo1 { get; set; }
  146. public int[] jo2 { get; set; }
  147. public int[] jo3 { get; set; }
  148. public int[] jo4 { get; set; }
  149. public int[] jo5 { get; set; }
  150. public int[] jo6 { get; set; }
  151. public int[] jo7 { get; set; }
  152. public int[] jo8 { get; set; }
  153. public int[] jo9 { get; set; }
  154. public int[] jo10 { get; set; }
  155. }
  156. /// <summary>
  157. /// 质合走势图遗漏模型
  158. /// </summary>
  159. public class Fcbjpk10ZhMissInfo
  160. {
  161. /// <summary>
  162. /// 名称
  163. /// </summary>
  164. public string name { get; set; }
  165. public int[] zh1 { get; set; }
  166. public int[] zh2 { get; set; }
  167. public int[] zh3 { get; set; }
  168. public int[] zh4 { get; set; }
  169. public int[] zh5 { get; set; }
  170. public int[] zh6 { get; set; }
  171. public int[] zh7 { get; set; }
  172. public int[] zh8 { get; set; }
  173. public int[] zh9 { get; set; }
  174. public int[] zh10 { get; set; }
  175. }
  176. /// <summary>
  177. /// 大小走势图遗漏模型
  178. /// </summary>
  179. public class Fcbjpk10DxMissInfo
  180. {
  181. /// <summary>
  182. /// 名称
  183. /// </summary>
  184. public string name { get; set; }
  185. public int[] dx1 { get; set; }
  186. public int[] dx2 { get; set; }
  187. public int[] dx3 { get; set; }
  188. public int[] dx4 { get; set; }
  189. public int[] dx5 { get; set; }
  190. public int[] dx6 { get; set; }
  191. public int[] dx7 { get; set; }
  192. public int[] dx8 { get; set; }
  193. public int[] dx9 { get; set; }
  194. public int[] dx10 { get; set; }
  195. }
  196. #endregion
  197. #region 数据库操作
  198. /// <summary>
  199. /// 北京PK10
  200. /// </summary>
  201. public class Fcbjpk10Data : DataConnect
  202. {
  203. private static readonly object _lock = new object();
  204. /// <summary>
  205. /// 添加数据
  206. /// </summary>
  207. /// <param name="model"></param>
  208. /// <returns></returns>
  209. public static int Add(Fcbjpk10Info model)
  210. {
  211. if (model == null && model.id <= 0)
  212. return 0;
  213. List<int> kjh = new List<int>() { model.n1,model.n2,model.n3,model.n4,model.n5,model.n6, model.n7, model.n8, model.n9, model.n10 };
  214. model.opencode = $"{model.n1},{model.n2},{model.n3},{model.n4},{model.n5},{model.n6},{model.n7},{model.n8},{model.n9},{model.n10}";
  215. model.hz = kjh.Sum();
  216. model.kd = kjh.Max() - kjh.Min();
  217. model.addtime = DateTime.Now;
  218. lock (_lock)
  219. {
  220. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  221. {
  222. if (db.Exists<Fcbjpk10Info>($"where qi={model.qi}"))
  223. return 0;
  224. int ret = TypeConverter.ObjectToInt(db.Insert(model));
  225. try
  226. {
  227. //更新api
  228. DoHttpHelp.UpdateWebApi(GPEnum.fcbjpk10.ToString());
  229. }
  230. catch (Exception) { }
  231. return ret;
  232. }
  233. }
  234. }
  235. /// <summary>
  236. /// 最新一期
  237. /// </summary>
  238. /// <returns></returns>
  239. public static Fcbjpk10Info GetFcbjpk10NewInfo()
  240. {
  241. string sql = string.Format("where n1>-1 order by qi desc limit 1 ");
  242. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  243. {
  244. return db.SingleOrDefault<Fcbjpk10Info>(sql);
  245. }
  246. }
  247. /// <summary>
  248. /// 最近N期的数据列表
  249. /// </summary>
  250. /// <returns></returns>
  251. public static List<Fcbjpk10Info> GetList()
  252. {
  253. const string sql = "order by qi desc limit 2000";
  254. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  255. {
  256. var list = db.Fetch<Fcbjpk10Info>(sql);
  257. var outlist = new List<Fcbjpk10Info>();
  258. if (list != null && list.Count > 0)
  259. {
  260. var size = list.Count;
  261. for (int i = 0; i < size; i++)
  262. {
  263. Fcbjpk10Info info = list[i];
  264. info.rank = i + 1;
  265. outlist.Add(info);
  266. }
  267. }
  268. return outlist;
  269. }
  270. }
  271. public static Fcbjpk10Info GetNewQiTop1(int dateint)
  272. {
  273. string sql = string.Empty;
  274. if (dateint == 0)
  275. {
  276. sql = string.Format("order by qi desc limit 1");
  277. }
  278. else
  279. {
  280. string _qistr = dateint.ToString() + "00";
  281. sql = string.Format("where qi<{0} order by qi desc limit 1", _qistr);
  282. }
  283. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  284. {
  285. return db.SingleOrDefault<Fcbjpk10Info>(sql);
  286. }
  287. }
  288. /// <summary>
  289. /// 返回指定条件的最新期数,dateint=0,返回所有数据中的最新一条,即无附加条件的最新。
  290. /// 用于组合今天,昨天,前天的查询条件。
  291. /// </summary>
  292. /// <param name="dateint"></param>
  293. /// <returns></returns>
  294. public static string GetNewQiTop1Qi(int dateint)
  295. {
  296. int qi = TypeConverter.ObjectToInt(GetNewQiTop1(dateint).qi, 0);
  297. return qi.ToString();
  298. }
  299. /// <summary>
  300. /// 某一天的
  301. /// </summary>
  302. /// <param name="sqi"></param>
  303. /// <param name="eqi"></param>
  304. /// <returns></returns>
  305. public static List<Fcbjpk10Info> GetOneDayKjList(DateTime sqi, DateTime eqi)
  306. {
  307. string sql = string.Format("where date BETWEEN '{0}' AND '{1}'", sqi, eqi);
  308. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  309. {
  310. List<Fcbjpk10Info> list = db.Fetch<Fcbjpk10Info>(sql);
  311. if (list != null && list.Count > 0)
  312. {
  313. for (int i = 0; i < list.Count; i++)
  314. {
  315. if (list[i].qi.ToString().Length > 8)
  316. {
  317. list[i].qi = TypeConverter.StrToInt(list[i].qi.ToString().Substring(2), 0);
  318. }
  319. }
  320. }
  321. return list;
  322. }
  323. }
  324. }
  325. #endregion
  326. }