• 在使用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不失为一个好的选择)
  • 相关阅读:
    【从0安装】mysql
    Java面试题整理(待完善)
    Linux部署Java项目
    执行旧命令的几种方法
    SQL Server死锁报错分析
    枚举类中枚举值不存在.valueOf(enum) 抛异常处理
    InitializingBean的项目开发使用
    巧用枚举来干掉if-else,代码更优雅!
    使用Docker安装配置GitLab CE
    批量条件导出之---CSV
  • 原文地址:https://www.cnblogs.com/jimsfriend/p/9071075.html
Copyright © 2020-2023  润新知