123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 |
- 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<int> 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<List<SatInfo>> 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<dynamic>(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;
- }
- }
- /// <summary>
- /// 获取数据库所有双行根数
- /// </summary>
- /// <returns></returns>
- public static async Task<List<XlInfo>> 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<XlInfo>(sql).ToListAsync();
- return res;
- }
- }
- catch (Exception ex)
- {
- XdCxRhDW.Framework.LogHelper.Error("加载分页星历信息异常", ex);
- return null;
- }
- }
- /// <summary>
- /// 获取某个星某个时刻最近的双行根(可能返回null)
- /// </summary>
- /// <param name="satCode">卫星编号</param>
- /// <param name="sigTime">时刻</param>
- /// <returns></returns>
- public static async Task<XlInfo> 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<XlInfo>(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<XlInfo>(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;
- }
- }
- }
- }
|