XlRepository.cs 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. using System;
  2. using System.Collections;
  3. using System.Collections.Generic;
  4. using System.Data.Entity;
  5. using System.IO;
  6. using System.Linq;
  7. using System.Text;
  8. using System.Threading.Tasks;
  9. using XdCxRhDW.Entity;
  10. using Dapper;
  11. using XdCxRhDW.Framework;
  12. using MySql.Data.MySqlClient;
  13. namespace XdCxRhDW.Repostory
  14. {
  15. public static class XlRepository
  16. {
  17. public static async Task<int> GetCount(int? satCode)
  18. {
  19. using (MySqlContext db = new MySqlContext())
  20. {
  21. if (satCode == null)
  22. {
  23. var count = await db.XlInfos.CountAsync();
  24. return count;
  25. }
  26. else
  27. {
  28. var count = await db.XlInfos.Where(w => w.SatCode == satCode).CountAsync();
  29. return count;
  30. }
  31. }
  32. }
  33. public static async Task<List<SatInfo>> GetAllSatAsync()
  34. {
  35. try
  36. {
  37. var str = AppConfigHelper.GetConnectionString("MySql");
  38. using (MySqlConnection con = new MySqlConnection(str))
  39. {
  40. string sql = "select SatCode,SatName,Lon from XlInfo where id in (select max(id) maxid from xlinfo group by satcode) order by satcode";
  41. var data = await con.QueryAsync<dynamic>(sql);
  42. var sats = data.Select(p => new SatInfo()
  43. {
  44. SatCode = p.SatCode,
  45. SatName = p.SatName,
  46. SatLon = p.Lon,
  47. }).ToList();
  48. return sats;
  49. }
  50. }
  51. catch (Exception ex)
  52. {
  53. XdCxRhDW.Framework.LogHelper.Error("获取星历表所有卫星信息异常", ex);
  54. return null;
  55. }
  56. }
  57. /// <summary>
  58. /// 获取数据库所有双行根数
  59. /// </summary>
  60. /// <returns></returns>
  61. public static async Task<List<XlInfo>> GetPageAsync(int currentPage, int pageSize, int? satCode)
  62. {
  63. try
  64. {
  65. using (MySqlContext db = new MySqlContext())
  66. {
  67. var topNumber = (currentPage - 1) * pageSize;
  68. StringBuilder sb = new StringBuilder();
  69. sb.Append($"select * from xlinfo ");
  70. if (satCode != null)
  71. {
  72. sb.Append($"where SatCode={satCode} ");
  73. }
  74. sb.Append($"order by TimeUTC desc limit {pageSize} offset {topNumber}");
  75. string sql = sb.ToString();
  76. var res = await db.Database.SqlQuery<XlInfo>(sql).ToListAsync();
  77. return res;
  78. }
  79. }
  80. catch (Exception ex)
  81. {
  82. XdCxRhDW.Framework.LogHelper.Error("加载分页星历信息异常", ex);
  83. return null;
  84. }
  85. }
  86. /// <summary>
  87. /// 获取某个星某个时刻最近的双行根(可能返回null)
  88. /// </summary>
  89. /// <param name="satCode">卫星编号</param>
  90. /// <param name="sigTime">时刻</param>
  91. /// <returns></returns>
  92. public static async Task<XlInfo> GetLatestAsync(int satCode, DateTime sigTime)
  93. {
  94. try
  95. {
  96. //GetLatestAsync方法在索引列上使用了加减运算会导致索引失效,运算变慢,这个函数是对GetLatestAsyncOld的优化
  97. //老的SQL很慢
  98. //SELECT min(abs(JULIANDAY(TimeUTC)-JULIANDAY('2024-10-09 23:59:53'))) as NearDaySpan,* FROM XlInfo where satcode=40892
  99. using (MySqlContext db = new MySqlContext())
  100. {
  101. string sql = $"select * from XlInfo where SatCode={satCode} and TimeUTC>='{sigTime:yyyy-MM-dd HH:mm:ss}' order by TimeUTC limit 1";
  102. var max = await db.Database.SqlQuery<XlInfo>(sql).FirstOrDefaultAsync();
  103. sql = $"select * from XlInfo where SatCode={satCode} and TimeUTC<='{sigTime:yyyy-MM-dd HH:mm:ss}' order by TimeUTC desc limit 1";
  104. var min = await db.Database.SqlQuery<XlInfo>(sql).FirstOrDefaultAsync();
  105. if (max == null && min == null)
  106. return null;
  107. else if (max != null && min == null)
  108. return max;
  109. else if (max == null && min != null)
  110. return min;
  111. else
  112. {
  113. //谁离得更接近就用谁
  114. var val1 = Math.Abs((max.TimeUTC - sigTime).TotalSeconds);
  115. var val2 = Math.Abs((min.TimeUTC - sigTime).TotalSeconds);
  116. if (val1 < val2)
  117. return max;
  118. else
  119. return min;
  120. }
  121. }
  122. }
  123. catch (Exception ex)
  124. {
  125. XdCxRhDW.Framework.LogHelper.Error($"获取卫星[{satCode}]--{sigTime:yyyyMMddHHmmss}时刻附近的双行根数出错!", ex);
  126. return null;
  127. }
  128. }
  129. }
  130. }