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.Repostory.EFContext;
using XdCxRhDW.Repostory.Model;
namespace XdCxRhDW.Repostory
{
public static class XlCache
{
///
/// 获取数据库所有双行根数
///
/// 最大条数.超过此条数时不再继续查询,为0则不限制条数
///
public static async Task> GetAllAsync(int maxCount = 2000)
{
try
{
List list = new List();
var dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "DbPart");
if (!Directory.Exists(dir)) return list;
var yearDirs = Directory.EnumerateDirectories(dir).OrderByDescending(p => Convert.ToInt32(new DirectoryInfo(p).Name));//年目录,倒叙排列
foreach (var yearDir in yearDirs)
{
//每一天的db文件,倒序排列
var dayFiles = Directory.EnumerateFiles(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, yearDir), "*.db").OrderByDescending(p => Convert.ToInt32(new DirectoryInfo(p).Name.Substring(0, 4)));
foreach (var dayFile in dayFiles)
{
using (RHDWPartContext db = RHDWPartContext.GetContext(dayFile))
{
list.AddRange(await db.XlInfos.ToListAsync());
if (maxCount > 0 && list.Count >= maxCount)
return list;
}
}
}
return list;
}
catch (Exception ex)
{
Serilog.Log.Error(ex, "加载星历信息异常");
return null;
}
}
///
/// 获取某个星某个时刻最近的双行根(可能返回null)
///
/// 卫星编号
/// 时刻
///
public static async Task GetLatestAsync(int satCode, DateTime timeBj)
{
try
{
var list = await GetAllAsync(0);
if (!list.Any()) return null;
var mainXl = list.Where(w => w.SatCode == satCode);
var minSec = mainXl.Min(p => Math.Abs((p.TimeBJ - timeBj).TotalSeconds));
var find = mainXl.FirstOrDefault(p => Math.Abs((p.TimeBJ - timeBj).TotalSeconds) == minSec);
return find;
}
catch (Exception ex)
{
Serilog.Log.Error(ex, $"获取卫星[{satCode}]--{timeBj:yyyyMMddHHmmss}时刻附近的双行根数出错!");
return null;
}
}
}
}