记一次EF查询返回无结果问题

3 篇文章 0 订阅
1 篇文章 0 订阅

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

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

闪耀星星

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值