LINQ 语句中格式化日期

在使用LINQ进行数据筛选时,如果涉及到日期格式化,不能直接在实体Entity上使用ToString()方法,这会导致错误。正确的做法是先将数据库数据转化为List,然后在List中进行日期格式化操作,从而避免错误。示例代码演示了如何正确地在LINQ查询中处理日期格式化问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文地址: https://www.jeremyjone.com/656/,转载请注明。


LINQ中经常需要进行数据判断进行筛选,如果遇到需要对日期进行格式化,需要注意不能在实体Entity中直接格式化日期,这样会报错,而是需要先将实体转换,再筛选。

例如:

var day = "2020-04-20";
var r = _db.PlanDay.FirstOrDefault(x=>x.Validity && string.Equals(x.CreateTime.ToString("yyyy-MM-dd"), day));

上面这样写,直接崩掉,因为直接对CreateTime实体字段使用ToString()方法。

应该修改为如下,即可解决问题:

var day = "2020-04-20";
var r = _db.PlanDay.ToList().FirstOrDefault(x=>x.Validity && string.Equals(x.CreateTime.ToString("yyyy-MM-dd"), day));

先将数据库所有数据转为List,再查找,就可以简单有效的解决问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值