mirror of
https://github.com/ClemensFischer/XAML-Map-Control.git
synced 2025-12-06 07:12:04 +01:00
Update FileDbCache.cs
This commit is contained in:
parent
691e19ebea
commit
1338d0d1cc
|
|
@ -89,11 +89,14 @@ namespace MapControl.Caching
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var record = fileDb.GetRecordByKey(key, new string[] { valueField, expiresField }, false);
|
lock (fileDb)
|
||||||
|
|
||||||
if (record != null && (DateTime)record[1] > DateTime.UtcNow)
|
|
||||||
{
|
{
|
||||||
value = (byte[])record[0];
|
var record = fileDb.GetRecordByKey(key, new string[] { valueField, expiresField }, false);
|
||||||
|
|
||||||
|
if (record != null && (DateTime)record[1] > DateTime.UtcNow)
|
||||||
|
{
|
||||||
|
value = (byte[])record[0];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
|
|
@ -120,14 +123,17 @@ namespace MapControl.Caching
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (fileDb.GetRecordByKey(key, new string[0], false) != null)
|
lock (fileDb)
|
||||||
{
|
{
|
||||||
fileDb.UpdateRecordByKey(key, fieldValues);
|
if (fileDb.GetRecordByKey(key, new string[0], false) != null)
|
||||||
}
|
{
|
||||||
else
|
fileDb.UpdateRecordByKey(key, fieldValues);
|
||||||
{
|
}
|
||||||
fieldValues.Add(keyField, key);
|
else
|
||||||
fileDb.AddRecord(fieldValues);
|
{
|
||||||
|
fieldValues.Add(keyField, key);
|
||||||
|
fileDb.AddRecord(fieldValues);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
|
|
@ -146,7 +152,10 @@ namespace MapControl.Caching
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
fileDb.DeleteRecordByKey(key);
|
lock (fileDb)
|
||||||
|
{
|
||||||
|
fileDb.DeleteRecordByKey(key);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
|
|
@ -156,12 +165,16 @@ namespace MapControl.Caching
|
||||||
|
|
||||||
public void DeleteExpiredItems()
|
public void DeleteExpiredItems()
|
||||||
{
|
{
|
||||||
var deleted = fileDb.DeleteRecords(new FilterExpression(expiresField, DateTime.UtcNow, ComparisonOperatorEnum.LessThanOrEqual));
|
lock (fileDb)
|
||||||
|
|
||||||
if (deleted > 0)
|
|
||||||
{
|
{
|
||||||
Debug.WriteLine($"{nameof(FileDbCache)}: Deleted {deleted} expired items");
|
var deleted = fileDb.DeleteRecords(new FilterExpression(expiresField, DateTime.UtcNow, ComparisonOperatorEnum.LessThanOrEqual));
|
||||||
fileDb.Clean();
|
|
||||||
|
if (deleted > 0)
|
||||||
|
{
|
||||||
|
fileDb.Clean();
|
||||||
|
|
||||||
|
Debug.WriteLine($"{nameof(FileDbCache)}: Deleted {deleted} expired items");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue