按時間查詢,一開始是這麼寫的,咋看好像沒有問題;當開始時間和結束時間同時傳的時候,會發生什麼……………,查詢不到資料; 發生了什麼呢?!query生成的SQL,我拷貝出來,參數替換了,是有資料的,這個讓我折騰了很一會兒!
DateTime time = DateTime.Now;
if (!string.IsNullOrEmpty(queryInfo.createStart))
{
DateTime.TryParse(queryInfo.createStart, out time);
query = query.Where(i => i.F_CreatorTime >= time);
}
if (!string.IsNullOrEmpty(queryInfo.createEnd))
{
DateTime.TryParse(queryInfo.createEnd, out time);
time = time.AddDays(1);
query = query.Where(i => i.F_CreatorTime <= time);
}
通過以下代碼(來自網絡)跟蹤,檢視參數,才發現開始時間和結束時間是相同的值,(相同的值),回過頭來,看參數值,确實是一個日期執行個體,第二次結束時間把開始時間覆寫了;問題原因找到了;回頭把系統所有的EF查詢的地方,檢查了參數問題!
public static string ToTraceString<T>(IQueryable<T> query)
{
var internalQueryField = query.GetType().GetFields(System.Reflection.BindingFlags.NonPublic | System.Reflection.BindingFlags.Instance).Where(f => f.Name.Equals("_internalQuery")).FirstOrDefault();
var internalQuery = internalQueryField.GetValue(query);
var objectQueryField = internalQuery.GetType().GetFields(System.Reflection.BindingFlags.NonPublic | System.Reflection.BindingFlags.Instance).Where(f => f.Name.Equals("_objectQuery")).FirstOrDefault();
var objectQuery = objectQueryField.GetValue(internalQuery) as System.Data.Entity.Core.Objects.ObjectQuery<T>;
return ToTraceStringWithParameters<T>(objectQuery);
}
public static string ToTraceStringWithParameters<T>(System.Data.Entity.Core.Objects.ObjectQuery<T> query)
{
System.Text.StringBuilder sb = new StringBuilder();
string traceString = query.ToTraceString() + Environment.NewLine;
foreach (var parameter in query.Parameters)
{
traceString += parameter.Name + " [" + parameter.ParameterType.FullName + "] = " + parameter.Value + "\n";
}
return traceString;
}