Tcsxytdj.cs 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355
  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("tcsxytdj"), PrimaryKey("id")]
  15. public class TcsxytdjInfo
  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. /// <summary>
  38. /// 号码四
  39. /// </summary>
  40. public int n4 { get; set; }
  41. /// <summary>
  42. /// 开奖号字串
  43. /// 01,02,03,04,05
  44. /// </summary>
  45. public string opencode { get; set; }
  46. /// <summary>
  47. /// 和值
  48. /// </summary>
  49. public int hz { get; set; }
  50. /// <summary>
  51. /// 跨度
  52. /// </summary>
  53. public int kd { get; set; }
  54. /// <summary>
  55. /// 开奖时间
  56. /// </summary>
  57. public DateTime date { get; set; }
  58. /// <summary>
  59. /// 数据入库时间
  60. /// </summary>
  61. public DateTime addtime { get; set; }
  62. /// <summary>
  63. /// 是否有错误标记 0:无 1:有
  64. /// </summary>
  65. public int iserror { set; get; }
  66. /// <summary>
  67. /// 是否有异常 0:无异常 1:有异常 2:人工已处理无异常
  68. /// </summary>
  69. public int isexception { set; get; }
  70. /// <summary>
  71. /// 来源 0:mongo 1:后台手工
  72. /// </summary>
  73. public int origin { set; get; }
  74. [Ignore]
  75. public int rank { get; set; }
  76. }
  77. #endregion
  78. #region 遗漏模型
  79. /// <summary>
  80. /// 出号走势图上的遗漏模型
  81. /// </summary>
  82. public class TcsxytdjJbzsMissInfo
  83. {
  84. public string name { get; set; }
  85. /// <summary>
  86. /// 第一位
  87. /// </summary>
  88. public int[] hm1 { get; set; }
  89. /// <summary>
  90. /// 第二位
  91. /// </summary>
  92. public int[] hm2 { set; get; }
  93. /// <summary>
  94. /// 第三位
  95. /// </summary>
  96. public int[] hm3 { get; set; }
  97. /// <summary>
  98. /// 第四位
  99. /// </summary>
  100. public int[] hm4 { set; get; }
  101. }
  102. /// <summary>
  103. /// 出号走势图上的遗漏模型
  104. /// </summary>
  105. public class TcsxytdjChzsMissInfo
  106. {
  107. public string name { get; set; }
  108. /// <summary>
  109. /// 组选形态
  110. /// </summary>
  111. public int[] zxxt { get; set; }
  112. /// <summary>
  113. /// 出号
  114. /// </summary>
  115. public int[] ch { get; set; }
  116. /// <summary>
  117. /// 大小比
  118. /// </summary>
  119. public int[] dxb { set; get; }
  120. /// <summary>
  121. /// 奇偶比
  122. /// </summary>
  123. public int[] job { set; get; }
  124. /// <summary>
  125. /// 质合比
  126. /// </summary>
  127. public int[] zhb { set; get; }
  128. }
  129. /// <summary>
  130. /// 和值走势图上的遗漏模型
  131. /// </summary>
  132. public class TcsxytdjHzzsMissInfo
  133. {
  134. public string name { get; set; }
  135. /// <summary>
  136. /// 组选形态
  137. /// </summary>
  138. public int[] zxxt { get; set; }
  139. /// <summary>
  140. /// 和值
  141. /// </summary>
  142. public int[] hz { get; set; }
  143. }
  144. /// <summary>
  145. /// 大小形态走势图上的遗漏模型
  146. /// </summary>
  147. public class TcsxytdjDxxtMissInfo
  148. {
  149. public string name { get; set; }
  150. /// <summary>
  151. /// 大小形态
  152. /// </summary>
  153. public int[] dxxt { get; set; }
  154. }
  155. /// <summary>
  156. /// 奇偶形态走势图上的遗漏模型
  157. /// </summary>
  158. public class TcsxytdjJoxtMissInfo
  159. {
  160. public string name { get; set; }
  161. /// <summary>
  162. /// 奇偶形态
  163. /// </summary>
  164. public int[] joxt { get; set; }
  165. }
  166. /// <summary>
  167. /// 质合形态走势图上的遗漏模型
  168. /// </summary>
  169. public class TcsxytdjZhxtMissInfo
  170. {
  171. public string name { get; set; }
  172. /// <summary>
  173. /// 质合形态
  174. /// </summary>
  175. public int[] zhxt { get; set; }
  176. }
  177. #endregion
  178. #region 数据库操作
  179. /// <summary>
  180. /// 体彩山西泳坛夺金
  181. /// </summary>
  182. public class TcsxytdjData : DataConnect
  183. {
  184. private static readonly object _lock = new object();
  185. /// <summary>
  186. /// 添加数据
  187. /// </summary>
  188. /// <param name="model"></param>
  189. /// <returns></returns>
  190. public static int Add(TcsxytdjInfo model)
  191. {
  192. if (model == null && model.id <= 0)
  193. return 0;
  194. List<int> kjh = new List<int>() { model.n1,model.n2,model.n3, model.n4};
  195. model.opencode = $"{model.n1},{model.n2},{model.n3},{model.n4}";
  196. model.hz = kjh.Sum();
  197. model.kd = kjh.Max() - kjh.Min();
  198. model.addtime = DateTime.Now;
  199. lock (_lock)
  200. {
  201. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  202. {
  203. if (db.Exists<TcsxytdjInfo>($"where qi={model.qi}"))
  204. return 0;
  205. int ret = TypeConverter.ObjectToInt(db.Insert(model));
  206. try
  207. {
  208. //更新api
  209. DoHttpHelp.UpdateWebApi(GPEnum.tcsxytdj.ToString());
  210. }
  211. catch (Exception) { }
  212. return ret;
  213. }
  214. }
  215. }
  216. /// <summary>
  217. /// 最新一期
  218. /// </summary>
  219. /// <returns></returns>
  220. public static TcsxytdjInfo GetTcsxytdjNewInfo()
  221. {
  222. string sql = string.Format("where n1>-1 order by qi desc limit 1 ");
  223. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  224. {
  225. return db.SingleOrDefault<TcsxytdjInfo>(sql);
  226. }
  227. }
  228. /// <summary>
  229. /// 最近N期的数据列表
  230. /// </summary>
  231. /// <returns></returns>
  232. public static List<TcsxytdjInfo> GetList()
  233. {
  234. const string sql = "order by qi desc limit 2000";
  235. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  236. {
  237. var list = db.Fetch<TcsxytdjInfo>(sql);
  238. var outlist = new List<TcsxytdjInfo>();
  239. if (list != null && list.Count > 0)
  240. {
  241. var size = list.Count;
  242. for (int i = 0; i < size; i++)
  243. {
  244. TcsxytdjInfo info = list[i];
  245. info.rank = i + 1;
  246. outlist.Add(info);
  247. }
  248. }
  249. return outlist;
  250. }
  251. }
  252. public static TcsxytdjInfo GetNewQiTop1(int dateint)
  253. {
  254. string sql = string.Empty;
  255. if (dateint == 0)
  256. {
  257. sql = string.Format("order by qi desc limit 1");
  258. }
  259. else
  260. {
  261. string _qistr = dateint.ToString() + "00";
  262. sql = string.Format("where qi<{0} order by qi desc limit 1", _qistr);
  263. }
  264. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  265. {
  266. return db.SingleOrDefault<TcsxytdjInfo>(sql);
  267. }
  268. }
  269. /// <summary>
  270. /// 返回指定条件的最新期数,dateint=0,返回所有数据中的最新一条,即无附加条件的最新。
  271. /// 用于组合今天,昨天,前天的查询条件。
  272. /// </summary>
  273. /// <param name="dateint"></param>
  274. /// <returns></returns>
  275. public static string GetNewQiTop1Qi(int dateint)
  276. {
  277. int qi = TypeConverter.ObjectToInt(GetNewQiTop1(dateint).qi, 0);
  278. return qi.ToString();
  279. }
  280. /// <summary>
  281. /// 某一天的
  282. /// </summary>
  283. /// <param name="sqi"></param>
  284. /// <param name="eqi"></param>
  285. /// <returns></returns>
  286. public static List<TcsxytdjInfo> GetOneDayKjList(DateTime sqi, DateTime eqi)
  287. {
  288. string sql = string.Format("where date BETWEEN '{0}' AND '{1}'", sqi, eqi);
  289. using (Database db = new Database(mysql, MySqlClientFactory.Instance))
  290. {
  291. List<TcsxytdjInfo> list = db.Fetch<TcsxytdjInfo>(sql);
  292. if (list != null && list.Count > 0)
  293. {
  294. for (int i = 0; i < list.Count; i++)
  295. {
  296. if (list[i].qi.ToString().Length > 8)
  297. {
  298. list[i].qi = TypeConverter.StrToInt(list[i].qi.ToString().Substring(2), 0);
  299. }
  300. }
  301. }
  302. return list;
  303. }
  304. }
  305. }
  306. #endregion
  307. }