按时间查询,一开始是这么写的,咋看好像没有问题;当开始时间和结束时间同时传的时候,会发生什么……………,查询不到数据; 发生了什么呢?!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;
}