在使用EF时,想要比较字符串类型的日期时

原文地址(https://blog.csdn.net/yangxinyue315/article/details/44960895)

在使用EF时,想要比较字符串类型的日期时

在使用EF时,想要比较字符串类型的日期时,参考以下:

SQL语句:

1)select * from TableName where StartTime > ‘2015-04-08’ 
2)select * from TableName where StartTime >= ‘2015-04-08’ 
3)select * from TableName where StartTime < ‘2015-04-08’ 
4)select * from TableName where StartTime <= ‘2015-04-08’ 
lambda表达式写法:

1).Where(a => a.StartTime.CompareTo(‘2015-04-08’) > 0) 
2).Where(a => a.StartTime.CompareTo(‘2015-04-08’) >= 0) 
3).Where(a => a.StartTime.CompareTo(‘2015-04-08’) < 0) 
4).Where(a => a.StartTime.CompareTo(‘2015-04-08’) <= 0) 
更规范的写法:

1).Where(a => String.Compare(a.StartTime, ‘2015-04-08’, StringComparison.Ordinal) > 0) 
2).Where(a => String.Compare(a.StartTime, ‘2015-04-08’, StringComparison.Ordinal) >= 0) 
3).Where(a => String.Compare(a.StartTime, ‘2015-04-08’, StringComparison.Ordinal) < 0) 
4).Where(a => String.Compare(a.StartTime, ‘2015-04-08’, StringComparison.Ordinal) <= 0)

(sqlserver和ef在日期datetime类型上面坑还是比较多(比如mvc返回json结果时,会自动把日期类型转化为时间戳,比如sqlserver比较datetime类型的大小要比varchar类型复杂),实际使用时,日期类型使用varachar不失为一个好的选择)
posted @ 2018-05-22 11:16  小小爵  阅读(784)  评论(0编辑  收藏  举报