Fcsdqyh.cs 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336
  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. /// 山东群英会
  13. /// </summary>
  14. [TableName("fcsdqyh"), PrimaryKey("id")]
  15. public class FcsdqyhInfo
  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. /// 基本走势图上的遗漏模型
  79. /// </summary>
  80. public class FcsdqyhJbzsMissInfo
  81. {
  82. public string name { get; set; }
  83. /// <summary>
  84. /// 出号
  85. /// </summary>
  86. public int[] ch { get; set; }
  87. }
  88. /// <summary>
  89. /// 围二走势图上的遗漏模型
  90. /// </summary>
  91. public class FcsdqyhWezsMissInfo
  92. {
  93. public string name { get; set; }
  94. /// <summary>
  95. /// 出号
  96. /// </summary>
  97. public int[] ch { get; set; }
  98. }
  99. /// <summary>
  100. /// 围三走势图上的遗漏模型
  101. /// </summary>
  102. public class FcsdqyhWszsMissInfo
  103. {
  104. public string name { get; set; }
  105. /// <summary>
  106. /// 出号
  107. /// </summary>
  108. public int[] ch { get; set; }
  109. }
  110. /// <summary>
  111. /// 围四走势图上的遗漏模型
  112. /// </summary>
  113. public class FcsdqyhWsizsMissInfo
  114. {
  115. public string name { get; set; }
  116. /// <summary>
  117. /// 出号
  118. /// </summary>
  119. public int[] ch { get; set; }
  120. }
  121. /// <summary>
  122. /// 和值走势图上的遗漏
  123. /// </summary>
  124. public class FcsdqyhHzMissInfo
  125. {
  126. public string name { get; set; }
  127. public int[] hz { get; set; }
  128. public int[] hw { get; set; }
  129. }
  130. /// <summary>
  131. /// 顺选遗漏模型
  132. /// </summary>
  133. public class FcsdqyhSxMissInfo
  134. {
  135. /// <summary>
  136. /// 名称
  137. /// </summary>
  138. public string name { get; set; }
  139. /// <summary>
  140. /// 号码
  141. /// </summary>
  142. public int[] hm { get; set; }
  143. /// <summary>
  144. /// 大小
  145. /// </summary>
  146. public int[] dx { get; set; }
  147. /// <summary>
  148. /// 奇偶
  149. /// </summary>
  150. public int[] jo { get; set; }
  151. /// <summary>
  152. /// 质合
  153. /// </summary>
  154. public int[] zh { get; set; }
  155. /// <summary>
  156. /// 012
  157. /// </summary>
  158. public int[] _012 { get; set; }
  159. }
  160. #endregion
  161. #region 数据库操作
  162. /// <summary>
  163. /// 山东群英会
  164. /// </summary>
  165. public class FcsdqyhData : DataConnect
  166. {
  167. private static readonly object _lock = new object();
  168. /// <summary>
  169. /// 添加数据
  170. /// </summary>
  171. /// <param name="model"></param>
  172. /// <returns></returns>
  173. public static int Add(FcsdqyhInfo model)
  174. {
  175. if (model == null && model.id <= 0)
  176. return 0;
  177. List<int> kjh = new List<int>() { model.n1,model.n2,model.n3,model.n4,model.n5};
  178. model.opencode = $"{model.n1},{model.n2},{model.n3},{model.n4},{model.n5}";
  179. model.hz = kjh.Sum();
  180. model.kd = kjh.Max() - kjh.Min();
  181. model.addtime = DateTime.Now;
  182. lock (_lock)
  183. {
  184. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  185. {
  186. if (db.Exists<FcsdqyhInfo>($"where qi={model.qi}"))
  187. return 0;
  188. int ret = TypeConverter.ObjectToInt(db.Insert(model));
  189. try
  190. {
  191. //更新api
  192. DoHttpHelp.UpdateWebApi(GPEnum.fcsdqyh.ToString());
  193. }
  194. catch (Exception) { }
  195. return ret;
  196. }
  197. }
  198. }
  199. /// <summary>
  200. /// 最新一期
  201. /// </summary>
  202. /// <returns></returns>
  203. public static FcsdqyhInfo GetFcsdqyhNewInfo()
  204. {
  205. string sql = string.Format("where n1>-1 order by qi desc limit 1 ");
  206. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  207. {
  208. return db.SingleOrDefault<FcsdqyhInfo>(sql);
  209. }
  210. }
  211. /// <summary>
  212. /// 最近N期的数据列表
  213. /// </summary>
  214. /// <returns></returns>
  215. public static List<FcsdqyhInfo> GetList()
  216. {
  217. const string sql = "order by qi desc limit 2000";
  218. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  219. {
  220. var list = db.Fetch<FcsdqyhInfo>(sql);
  221. var outlist = new List<FcsdqyhInfo>();
  222. if (list != null && list.Count > 0)
  223. {
  224. var size = list.Count;
  225. for (int i = 0; i < size; i++)
  226. {
  227. FcsdqyhInfo info = list[i];
  228. info.rank = i + 1;
  229. outlist.Add(info);
  230. }
  231. }
  232. return outlist;
  233. }
  234. }
  235. public static FcsdqyhInfo GetNewQiTop1(int dateint)
  236. {
  237. string sql = string.Empty;
  238. if (dateint == 0)
  239. {
  240. sql = string.Format("order by qi desc limit 1");
  241. }
  242. else
  243. {
  244. string _qistr = dateint.ToString() + "00";
  245. sql = string.Format("where qi<{0} order by qi desc limit 1", _qistr);
  246. }
  247. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  248. {
  249. return db.SingleOrDefault<FcsdqyhInfo>(sql);
  250. }
  251. }
  252. /// <summary>
  253. /// 返回指定条件的最新期数,dateint=0,返回所有数据中的最新一条,即无附加条件的最新。
  254. /// 用于组合今天,昨天,前天的查询条件。
  255. /// </summary>
  256. /// <param name="dateint"></param>
  257. /// <returns></returns>
  258. public static string GetNewQiTop1Qi(int dateint)
  259. {
  260. int qi = TypeConverter.ObjectToInt(GetNewQiTop1(dateint).qi, 0);
  261. return qi.ToString();
  262. }
  263. /// <summary>
  264. /// 某一天的
  265. /// </summary>
  266. /// <param name="sqi"></param>
  267. /// <param name="eqi"></param>
  268. /// <returns></returns>
  269. public static List<FcsdqyhInfo> GetOneDayKjList(DateTime sqi, DateTime eqi)
  270. {
  271. string sql = string.Format("where date BETWEEN '{0}' AND '{1}'", sqi, eqi);
  272. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  273. {
  274. List<FcsdqyhInfo> list = db.Fetch<FcsdqyhInfo>(sql);
  275. if (list != null && list.Count > 0)
  276. {
  277. for (int i = 0; i < list.Count; i++)
  278. {
  279. if (list[i].qi.ToString().Length > 8)
  280. {
  281. list[i].qi = TypeConverter.StrToInt(list[i].qi.ToString().Substring(2), 0);
  282. }
  283. }
  284. }
  285. return list;
  286. }
  287. }
  288. }
  289. #endregion
  290. }