負載基本I有一個問題。如果我使用LinqToSql,我的程序將加載我的數據庫到內存中。 小例子:使用LinqToSql而不在存儲器
//pageNumber = 1; pageSize = 100;
var result =
(
from a in db.Stats.AsEnumerable()
where (DictionaryFilter(a, sourceDictionary) && DateFilter(a, beginTime, endTime) && ErrorFilter(a, WarnLevel))
select a
);
var size = result.Count(); // size = 1007
var resultList = result.Skip((pageNumber-1)*pageSize).Take(pageSize).ToList();
return resultList;
DictionaryFilter,DateFilter和ErrorFilter是我過濾DATEBASE功能。在這之後我的程序使用了〜250Mb的Ram。 如果我不使用:
var size = result.Count();
我的程序使用〜120MB RAM。 在使用此代碼之前,我的程序使用〜35MB Ram。
如何使用計數,並採取功能不加載我的內存中的所有DATEBASE?
static bool DateFilter(Stat table, DateTime begin, DateTime end)
{
if ((table.RecordTime >= begin.ToFileTime()) && (table.RecordTime <= end.ToFileTime()))
{
return true;
}
return false;
}
static bool ErrorFilter(Stat table, bool[] WarnLevel)
{
if (WarnLevel[table.WarnLevel]) return true;
else return false;
}
static bool DictionaryFilter(Stat table, Dictionary<GetSourcesNameResult, bool> sourceDictionary)
{
foreach (var word in sourceDictionary)
{
if (table.SourceName == word.Key.SourceName)
{
return word.Value;
}
}
//
return false;
}
他也許不能只是省略'AsEnumerable'。看看他的過濾器,它看起來像是由一堆定製的內存中謂詞組成的。他必須將所有過濾條款轉換爲「表達式」。編輯:確切地說。 –
@WiktorZychla,如果你現在點擊「f5」... –
我在我的文章中添加了過濾功能。 – EXTRAM