天天看點

記一次EF查詢傳回無結果問題

按時間查詢,一開始是這麼寫的,咋看好像沒有問題;當開始時間和結束時間同時傳的時候,會發生什麼……………,查詢不到資料; 發生了什麼呢?!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;
}