Fcgxkl10f.cs 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  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. /// 广西快乐10分
  13. /// </summary>
  14. [TableName("fcgxkl10f"), PrimaryKey("id")]
  15. public class Fcgxkl10fInfo
  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. /// <summary>
  40. /// 开奖号字串
  41. /// 01,02,03,04,05
  42. /// </summary>
  43. public string opencode { get; set; }
  44. /// <summary>
  45. /// 和值
  46. /// </summary>
  47. public int hz { get; set; }
  48. /// <summary>
  49. /// 跨度
  50. /// </summary>
  51. public int kd { get; set; }
  52. /// <summary>
  53. /// 开奖时间
  54. /// </summary>
  55. public DateTime date { get; set; }
  56. /// <summary>
  57. /// 数据入库时间
  58. /// </summary>
  59. public DateTime addtime { get; set; }
  60. /// <summary>
  61. /// 是否有错误标记 0:无 1:有
  62. /// </summary>
  63. public int iserror { set; get; }
  64. /// <summary>
  65. /// 是否有异常 0:无异常 1:有异常 2:人工已处理无异常
  66. /// </summary>
  67. public int isexception { set; get; }
  68. /// <summary>
  69. /// 来源 0:mongo 1:后台手工
  70. /// </summary>
  71. public int origin { set; get; }
  72. [Ignore]
  73. public int rank { get; set; }
  74. }
  75. #endregion
  76. #region 数据库操作
  77. /// <summary>
  78. /// 广西快乐10分
  79. /// </summary>
  80. public class Fcgxkl10fData : DataConnect
  81. {
  82. private static readonly object _lock = new object();
  83. /// <summary>
  84. /// 添加数据
  85. /// </summary>
  86. /// <param name="model"></param>
  87. /// <returns></returns>
  88. public static int Add(Fcgxkl10fInfo model)
  89. {
  90. if (model == null && model.id <= 0)
  91. return 0;
  92. List<int> kjh = new List<int>() { model.n1,model.n2,model.n3,model.n4,model.n5};
  93. model.opencode = $"{model.n1},{model.n2},{model.n3},{model.n4},{model.n5}";
  94. model.hz = kjh.Sum();
  95. model.kd = kjh.Max() - kjh.Min();
  96. model.addtime = DateTime.Now;
  97. lock (_lock)
  98. {
  99. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  100. {
  101. if (db.Exists<Fcgxkl10fInfo>($"where qi={model.qi}"))
  102. return 0;
  103. int ret = TypeConverter.ObjectToInt(db.Insert(model));
  104. try
  105. {
  106. //更新api
  107. DoHttpHelp.UpdateWebApi(GPEnum.fcgxkl10f.ToString());
  108. }
  109. catch (Exception) { }
  110. return ret;
  111. }
  112. }
  113. }
  114. /// <summary>
  115. /// 最新一期
  116. /// </summary>
  117. /// <returns></returns>
  118. public static Fcgxkl10fInfo GetFcgxkl10fNewInfo()
  119. {
  120. string sql = string.Format("where n1>-1 order by qi desc limit 1 ");
  121. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  122. {
  123. return db.SingleOrDefault<Fcgxkl10fInfo>(sql);
  124. }
  125. }
  126. /// <summary>
  127. /// 最近N期的数据列表
  128. /// </summary>
  129. /// <returns></returns>
  130. public static List<Fcgxkl10fInfo> GetList(int limit = 2000)
  131. {
  132. string sql = $"order by qi desc limit {limit}";
  133. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  134. {
  135. var list = db.Fetch<Fcgxkl10fInfo>(sql).OrderBy(n => n.qi).ToList();
  136. var outlist = new List<Fcgxkl10fInfo>();
  137. if (list != null && list.Count > 0)
  138. {
  139. var size = list.Count;
  140. for (int i = 0; i < size; i++)
  141. {
  142. Fcgxkl10fInfo info = list[i];
  143. info.rank = i + 1;
  144. outlist.Add(info);
  145. }
  146. }
  147. return outlist;
  148. }
  149. }
  150. public static Fcgxkl10fInfo GetNewQiTop1(int dateint)
  151. {
  152. string sql = string.Empty;
  153. if (dateint == 0)
  154. {
  155. sql = string.Format("order by qi desc limit 1");
  156. }
  157. else
  158. {
  159. string _qistr = dateint.ToString() + "00";
  160. sql = string.Format("where qi<{0} order by qi desc limit 1", _qistr);
  161. }
  162. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  163. {
  164. return db.SingleOrDefault<Fcgxkl10fInfo>(sql);
  165. }
  166. }
  167. /// <summary>
  168. /// 返回指定条件的最新期数,dateint=0,返回所有数据中的最新一条,即无附加条件的最新。
  169. /// 用于组合今天,昨天,前天的查询条件。
  170. /// </summary>
  171. /// <param name="dateint"></param>
  172. /// <returns></returns>
  173. public static string GetNewQiTop1Qi(int dateint)
  174. {
  175. int qi = TypeConverter.ObjectToInt(GetNewQiTop1(dateint).qi, 0);
  176. return qi.ToString();
  177. }
  178. /// <summary>
  179. /// 某一天的
  180. /// </summary>
  181. /// <param name="sqi"></param>
  182. /// <param name="eqi"></param>
  183. /// <returns></returns>
  184. public static List<Fcgxkl10fInfo> GetOneDayKjList(DateTime sqi, DateTime eqi)
  185. {
  186. string sql = string.Format("where date BETWEEN '{0}' AND '{1}'", sqi, eqi);
  187. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  188. {
  189. List<Fcgxkl10fInfo> list = db.Fetch<Fcgxkl10fInfo>(sql);
  190. var outlist = new List<Fcgxkl10fInfo>();
  191. if (list != null && list.Count > 0)
  192. {
  193. var size = list.Count;
  194. for (int i = 0; i < size; i++)
  195. {
  196. Fcgxkl10fInfo info = list[i];
  197. info.rank = i + 1;
  198. outlist.Add(info);
  199. }
  200. }
  201. return outlist;
  202. }
  203. }
  204. }
  205. #endregion
  206. }