use*_*358 6 .net c# comparison datetime linq-to-sql
我有一个Linq查询返回到var类型myQry
var myQry = from .....
Run Code Online (Sandbox Code Playgroud)
这是一个很大的linq返回我需要进一步过滤的所有记录.在我的一个if条件中,我有一个像这样运行的过滤器来检查日期.我需要检查名称是否包含输入的名称,并确切地匹配生日.
我试过这个编译和运行,但没有正常工作
myQry.Where(x => x.FirstName.Contains(strName) && DateTime.Compare( x.BirthDt, searchDt)>=0).ToList()
Run Code Online (Sandbox Code Playgroud)
然后我尝试了这个,它抛出异常"DbArithmeticExpression参数必须有一个数字公共类型"
myQry.Where(x => x.FirstName.Contains(strName) && (x.BirthDt- searchDt).Days == 0).ToList();
Run Code Online (Sandbox Code Playgroud)
对于这种情况,当我在查询中使用where子句时,进行日期比较的最佳方法是什么?LinQ查询的where子句中不允许进行哪些操作?
谢谢你的时间...
在这种情况下,您可能希望通过SqlMethods类中的方法来使用 SQL Server 特定函数。
您的第二个查询可以重写为
myQry.Where(x => x.FirstName.Contains(strName) &&
SqlMethods.DateDiffDay(x.BirthDt, searchDt) == 0).ToList()
Run Code Online (Sandbox Code Playgroud)
这将被翻译成类似的东西
SELECT ... FROM Table WHERE FirstName
LIKE '@p0' AND DATEDIFF(Day, BirthDt, @p1) = @p2
Run Code Online (Sandbox Code Playgroud)
其中 p0、p1 和 p2 是参数。