Tcsdklpk3.cs 11 KB

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