using System; using System.Collections; using System.Collections.Generic; using System.Data.Entity; using System.IO; using System.Linq; using System.Text; using System.Threading.Tasks; using XdCxRhDW.Entity; using Dapper; using XdCxRhDW.Framework; using MySql.Data.MySqlClient; namespace XdCxRhDW.Repostory { public static class XlRepository { public static async Task GetCount(int? satCode) { using (MySqlContext db = new MySqlContext()) { if (satCode == null) { var count = await db.XlInfos.CountAsync(); return count; } else { var count = await db.XlInfos.Where(w => w.SatCode == satCode).CountAsync(); return count; } } } public static async Task> GetAllSatAsync() { try { var str = AppConfigHelper.GetConnectionString("MySql"); using (MySqlConnection con = new MySqlConnection(str)) { string sql = "select SatCode,SatName,Lon from XlInfo where id in (select max(id) maxid from xlinfo group by satcode) order by satcode"; var data = await con.QueryAsync(sql); var sats = data.Select(p => new SatInfo() { SatCode = p.SatCode, SatName = p.SatName, SatLon = p.Lon, }).ToList(); return sats; } } catch (Exception ex) { XdCxRhDW.Framework.LogHelper.Error("获取星历表所有卫星信息异常", ex); return null; } } /// /// 获取数据库所有双行根数 /// /// public static async Task> GetPageAsync(int currentPage, int pageSize, int? satCode) { try { using (MySqlContext db = new MySqlContext()) { var topNumber = (currentPage - 1) * pageSize; StringBuilder sb = new StringBuilder(); sb.Append($"select * from xlinfo "); if (satCode != null) { sb.Append($"where SatCode={satCode} "); } sb.Append($"order by TimeUTC desc limit {pageSize} offset {topNumber}"); string sql = sb.ToString(); var res = await db.Database.SqlQuery(sql).ToListAsync(); return res; } } catch (Exception ex) { XdCxRhDW.Framework.LogHelper.Error("加载分页星历信息异常", ex); return null; } } /// /// 获取某个星某个时刻最近的双行根(可能返回null) /// /// 卫星编号 /// 时刻 /// public static async Task GetLatestAsync(int satCode, DateTime sigTime) { try { //GetLatestAsync方法在索引列上使用了加减运算会导致索引失效,运算变慢,这个函数是对GetLatestAsyncOld的优化 //老的SQL很慢 //SELECT min(abs(JULIANDAY(TimeUTC)-JULIANDAY('2024-10-09 23:59:53'))) as NearDaySpan,* FROM XlInfo where satcode=40892 using (MySqlContext db = new MySqlContext()) { string sql = $"select * from XlInfo where SatCode={satCode} and TimeUTC>='{sigTime:yyyy-MM-dd HH:mm:ss}' order by TimeUTC limit 1"; var max = await db.Database.SqlQuery(sql).FirstOrDefaultAsync(); sql = $"select * from XlInfo where SatCode={satCode} and TimeUTC<='{sigTime:yyyy-MM-dd HH:mm:ss}' order by TimeUTC desc limit 1"; var min = await db.Database.SqlQuery(sql).FirstOrDefaultAsync(); if (max == null && min == null) return null; else if (max != null && min == null) return max; else if (max == null && min != null) return min; else { //谁离得更接近就用谁 var val1 = Math.Abs((max.TimeUTC - sigTime).TotalSeconds); var val2 = Math.Abs((min.TimeUTC - sigTime).TotalSeconds); if (val1 < val2) return max; else return min; } } } catch (Exception ex) { XdCxRhDW.Framework.LogHelper.Error($"获取卫星[{satCode}]--{sigTime:yyyyMMddHHmmss}时刻附近的双行根数出错!", ex); return null; } } } }