Dfgdhc1.cs 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Text;
  4. using System.Data;
  5. using CP.Common;
  6. using MC.ORM;
  7. using MySql.Data.MySqlClient;
  8. namespace CP.Model
  9. {
  10. #region 遗漏模型
  11. /// <summary>
  12. /// 好彩1季节走势图遗漏模型
  13. /// </summary>
  14. public class Hc1SxMissInfo
  15. {
  16. /// <summary>
  17. /// 名称
  18. /// </summary>
  19. public string name { get; set; }
  20. /// <summary>
  21. /// 生肖
  22. /// </summary>
  23. public int[] sx { get; set; }
  24. /// <summary>
  25. /// 季节
  26. /// </summary>
  27. public int[] jj { get; set; }
  28. /// <summary>
  29. /// 方位
  30. /// </summary>
  31. public int[] fw { get; set; }
  32. /// <summary>
  33. /// 大小
  34. /// </summary>
  35. public int[] dx { get; set; }
  36. /// <summary>
  37. /// 奇偶
  38. /// </summary>
  39. public int[] jo { get; set; }
  40. /// <summary>
  41. /// 质合
  42. /// </summary>
  43. public int[] zh { get; set; }
  44. }
  45. /// <summary>
  46. /// 好彩1出号走势图遗漏模型
  47. /// </summary>
  48. public class Hc1ChzsMissInfo
  49. {
  50. /// <summary>
  51. /// 名称
  52. /// </summary>
  53. public string name { get; set; }
  54. /// <summary>
  55. /// 号码
  56. /// </summary>
  57. public int[] fb { get; set; }
  58. }
  59. #endregion
  60. #region 广东好彩1基本模型
  61. /// <summary>
  62. /// 广东好彩1模型
  63. /// </summary>
  64. [TableName("gdhc1"), PrimaryKey("id")]
  65. public class Dfgdhc1Info
  66. {
  67. /// <summary>
  68. /// 期数
  69. /// </summary>
  70. public int qi { get; set; }
  71. /// <summary>
  72. ///开奖号
  73. /// </summary>
  74. public int n1 { get; set; }
  75. /// <summary>
  76. /// 开奖日期
  77. /// </summary>
  78. public DateTime date { get; set; }
  79. /// <summary>
  80. /// 星期
  81. /// </summary>
  82. public int week { get; set; }
  83. /// <summary>
  84. /// 在列表中的排名
  85. /// </summary>
  86. [Ignore]
  87. public int rank { get; set; }
  88. }
  89. #endregion
  90. #region 完整模型
  91. /// <summary>
  92. /// 广东好彩1完整模型
  93. /// </summary>
  94. [TableName("gdhc1"), PrimaryKey("id")]
  95. public class Dfgdhc1LongInfo : Dfgdhc1Info
  96. {
  97. /// <summary>
  98. /// 自动编号ID
  99. /// </summary>
  100. public int id { get; set; }
  101. /// <summary>
  102. /// 数字中奖注数
  103. /// </summary>
  104. public string zj1 { get; set; }
  105. /// <summary>
  106. /// 数字中奖金额
  107. /// </summary>
  108. public string jo1 { get; set; }
  109. /// <summary>
  110. /// 生肖中奖注数
  111. /// </summary>
  112. public string sx { get; set; }
  113. /// <summary>
  114. /// 生肖中奖金额
  115. /// </summary>
  116. public string sxjo { get; set; }
  117. /// <summary>
  118. /// 季节中奖注数
  119. /// </summary>
  120. public string jj { get; set; }
  121. /// <summary>
  122. /// 季节中奖金额
  123. /// </summary>
  124. public string jjjo { get; set; }
  125. /// <summary>
  126. /// 方位中奖注数
  127. /// </summary>
  128. public string fw { get; set; }
  129. /// <summary>
  130. /// 方位中奖金额
  131. /// </summary>
  132. public string fwjo { get; set; }
  133. /// <summary>
  134. /// 开奖详情json
  135. /// </summary>
  136. public string winbonus { set; get; }
  137. /// <summary>
  138. /// 添加时间
  139. /// </summary>
  140. public DateTime addtime { get; set; }
  141. /// <summary>
  142. /// 投注金额
  143. /// </summary>
  144. public string tzmoney { get; set; }
  145. /// <summary>
  146. /// 下期奖池
  147. /// </summary>
  148. public string nextmoney { get; set; }
  149. /// <summary>
  150. /// 是否复查
  151. /// </summary>
  152. public int ischeck { get; set; }
  153. /// <summary>
  154. /// 号码
  155. /// </summary>
  156. public string opencode { get; set; }
  157. /// <summary>
  158. /// 第1步(开奖号)状态 -1:未添加 2:完成 3:复查完成
  159. /// </summary>
  160. public int step1state { set; get; }
  161. /// <summary>
  162. /// 第2步(开奖详情)状态 -1:未添加 1:完成一半 2:完成 3:复查完成
  163. /// </summary>
  164. public int step2state { set; get; }
  165. [Ignore]
  166. public string isComplete
  167. {
  168. get
  169. {
  170. if (step2state == 3)
  171. return "<span style='color:green;'>是</span>";
  172. return "<span style='color:red;'>否</span>";
  173. }
  174. }
  175. }
  176. #endregion
  177. /// <summary>
  178. /// 广东好彩1的数据库操作
  179. /// </summary>
  180. public class Dfgdhc1Data : DataConnect
  181. {
  182. /// <summary>
  183. /// 返回所有广东好彩1的数据..
  184. /// </summary>
  185. /// <returns></returns>
  186. public static List<Dfgdhc1Info> GetDfgdhc1Data()
  187. {
  188. List<Dfgdhc1Info> list = new List<Dfgdhc1Info>();
  189. string sql = string.Format("order by qi asc");
  190. DataConnect dc = new DataConnect();
  191. list = dc.db.Fetch<Dfgdhc1Info>(sql);
  192. if (list != null && list.Count > 0)
  193. {
  194. for (int i = 0; i < list.Count; i++)
  195. {
  196. list[i].rank = i + 1;
  197. }
  198. }
  199. return list;
  200. }
  201. #region 开奖公告相关方法
  202. /// <summary>
  203. /// 获取开奖列表
  204. /// </summary>
  205. /// <param name="n">条数</param>
  206. /// <param name="type">默认0只有开奖号数据 1 带有开机号 2 带有试机号</param>
  207. /// <returns></returns>
  208. public static List<Dfgdhc1LongInfo> GetList(int n = 30, bool isall = false)
  209. {
  210. string sql = $"where n1 > -1 order by qi desc limit {n}";
  211. if (isall)
  212. {
  213. sql = $"where n1 > -1 order by qi desc";
  214. }
  215. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  216. {
  217. return db.Fetch<Dfgdhc1LongInfo>(sql);
  218. }
  219. }
  220. /// <summary>
  221. /// 最新开奖数据
  222. /// </summary>
  223. /// <returns></returns>
  224. public static Dfgdhc1LongInfo GetDfgdHc1NewInfo()
  225. {
  226. string sql = string.Format("where n1>-1 order by qi desc limit 1 ");
  227. DataConnect dc = new DataConnect();
  228. return dc.db.SingleOrDefault<Dfgdhc1LongInfo>(sql);
  229. }
  230. /// <summary>
  231. /// 最新30期完整开奖数据
  232. /// </summary>
  233. /// <returns></returns>
  234. public static List<Dfgdhc1LongInfo> GetDfgdHc1Top30(int n = 30)
  235. {
  236. string sql = string.Format($"order by qi desc limit {30}");
  237. DataConnect dc = new DataConnect();
  238. return dc.db.Fetch<Dfgdhc1LongInfo>(sql);
  239. }
  240. /// <summary>
  241. /// 返回指定期数的完整开奖信息
  242. /// </summary>
  243. /// <param name="qi"></param>
  244. /// <returns></returns>
  245. public static Dfgdhc1LongInfo GetDfgdHc1InfoByQi(int qi)
  246. {
  247. string sql = string.Empty;
  248. if (qi == 0)
  249. sql = string.Format("order by qi desc limit 1");
  250. else
  251. sql = string.Format("where qi={0} limit 1", qi);
  252. DataConnect dc = new DataConnect();
  253. Dfgdhc1LongInfo info = dc.db.SingleOrDefault<Dfgdhc1LongInfo>(sql);
  254. return info;
  255. }
  256. /// <summary>
  257. /// 根据年份取出当年所有期数
  258. /// </summary>
  259. /// <param name="year"></param>
  260. /// <returns></returns>
  261. public static List<int> GetDfgdHc1QiListByYear(int year)
  262. {
  263. List<int> rlist = new List<int>();
  264. string sql = string.Format("where qi like '{0}%' order by qi desc", year);
  265. DataConnect dc = new DataConnect();
  266. var list = dc.db.Fetch<Dfgdhc1Info>(sql);
  267. if (list != null && list.Count > 0)
  268. {
  269. for (int i = 0; i < list.Count; i++)
  270. {
  271. rlist.Add(list[i].qi);
  272. }
  273. }
  274. return rlist;
  275. }
  276. #endregion
  277. #region 开奖号抓取相关数据层方法
  278. private static readonly object _lock = new object();
  279. public static void Add(Dfgdhc1LongInfo info)
  280. {
  281. if (info == null)
  282. return;
  283. if (info.qi <= 0)
  284. return;
  285. info.opencode = $"{info.n1:00}+{ZstUtils.GetShengXiao(info.n1)},{ZstUtils.GetJiJie(info.n1)},{ZstUtils.GetFangWei(info.n1)}";
  286. //星期
  287. info.week = Utils.GetIntWeek(info.date.DayOfWeek.ToString());
  288. lock (_lock)
  289. {
  290. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  291. {
  292. if (db.Exists<Dfgdhc1LongInfo>($"where qi={info.qi}"))
  293. return;
  294. db.Insert(info);
  295. try
  296. {
  297. //更新api
  298. DoHttpHelp.UpdateWebApi(DFEnum.gdhc1.ToString());
  299. }
  300. catch (Exception) { }
  301. }
  302. }
  303. }
  304. public static void Update(Dfgdhc1LongInfo model)
  305. {
  306. if (model == null)
  307. return;
  308. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  309. {
  310. var entity = db.SingleOrDefault<Dfgdhc1LongInfo>(model.id);
  311. db.Update(entity);
  312. }
  313. }
  314. public static Dfgdhc1LongInfo GetLastOne()
  315. {
  316. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  317. {
  318. var entity = db.SingleOrDefault<Dfgdhc1LongInfo>($"order by qi desc limit 1");
  319. return entity;
  320. }
  321. }
  322. #endregion
  323. }
  324. }