using System;
using System.Collections.Generic;
using System.Data.Entity;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using XdCxRhDW.Entity;
namespace XdCxRhDW.Repostory
{
public static class XlRepository
{
///
/// 获取数据库所有双行根数
///
///
public static async Task> GetAllAsync()
{
try
{
using (RHDWContext db = new RHDWContext())
{
var res = await db.XlInfos.OrderByDescending(p => p.TimeUTC).OrderByDescending(p => p.Lon).ToListAsync();
return res;
}
}
catch (Exception ex)
{
Serilog.Log.Error(ex, "加载星历信息异常");
return null;
}
}
///
/// 获取某个星某个时刻最近的双行根(可能返回null)
///
/// 卫星编号
/// 时刻
///
public static async Task GetLatestAsync(int satCode, DateTime sigTime)
{
var sql = $"SELECT min(abs(JULIANDAY(TimeUTC)-JULIANDAY('{sigTime:yyyy-MM-dd HH:mm:ss}')))" +
$" as NearDaySpan,* FROM XlInfo where satcode={satCode}";
try
{
using (RHDWContext db = new RHDWContext())
{
var res= await db.XlInfos.SqlQuery(sql).FirstOrDefaultAsync();
return res;
}
}
catch (Exception ex)
{
Serilog.Log.Error(ex, $"获取卫星[{satCode}]--{sigTime:yyyyMMddHHmmss}时刻附近的双行根数出错!Sql={sql}");
return null;
}
}
}
}