【问题标题】:How to select a column based on date condition in LINQ query如何在 LINQ 查询中根据日期条件选择列
【发布时间】:2017-08-28 12:28:58
【问题描述】:

我的查询是我想选择出生日期为系统日期的用户列表,我在控制器中使用了以下条件,但它给出了错误。 我想省略年份,并选择出生日期与系统日期和月份相同的用户。

错误:

LINQ to Entities 无法识别方法 'System.String ToString(System.String)' 方法,并且该方法无法转换为存储表达式。

控制器代码:

objUser.UserBirthdays = dbContext.EmployeeProfiles.Where(u => Convert.ToDateTime(u.DOB).ToString("dd-MMM").Equals(DateTime.Now.ToString("dd-MMM"))).Select(u => u.Name).ToList();

UserBirthdays 在 model 中定义为:

public IEnumerable<string> UserBirthdays { get; set; }

如何解决此错误并获取用户名?

【问题讨论】:

  • var dob = DateTime.Now.ToString("dd-MMM"); objUser.UserBirthdays = dbContext.EmployeeProfiles.Where(u =&gt; u.DOB == dob).Select(u =&gt; u.Name).ToList();(但这取决于你的数据库中的 DOB)
  • DOB在数据库中的格式是什么,为什么是字符串而不是DateTime? (我假设它是string,否则你为什么要使用Convert.ToDateTime()
  • DOB 的数据类型是数据库中的日期时间。
  • 那么Convert.ToDateTime() 毫无意义。您是否要匹配 DOB 的日期和月份与今天的日期和月份匹配的所有记录(但可以是任何年份)
  • 是的。你明白我的意思。如果用户 A 和 B 的 DOB 是 1990 年 8 月 29 日和 1987 年 8 月 29 日,则它应该给出结果 A 和 B,仅匹配日期和月份部分。

标签: c# linq


【解决方案1】:

这将获得今天所有具有 DOB 的用户:

如果 DOB 是 DateTime 类型:

objUser.UserBirthdays = dbContext.EmployeeProfiles
                          .Where(u => u.DOB.Day == DateTime.Today.Day 
                                   && u.DOB.Month == DateTime.Today.Month)
                          .Select(u => u.Name).ToList();

如果DOB数据类型是Nullable DateTime (DateTime?),那么需要先检查空值,然后将DOB转换成DateTime

objUser.UserBirthdays = dbContext.EmployeeProfiles
                          .Where(u => u.DOB != null 
                                    && Convert.ToDateTime(u.DOB).Day == DateTime.Today.Day
                                    && Convert.ToDateTime(u.DOB).Month == DateTime.Today.Month)
                          .Select(u => u.Name).ToList();

【讨论】:

  • 删除ToList() 将推迟查询的执行(不一定是坏事,只是一个注释)
  • @yinnonsanders 添加了它
  • 这不起作用。请建议如何填充与日期和月份匹配的名称列表..
  • @SameepBaxi DOB 的类型是什么?是DateTime 还是DateTime? (nullable datetime)
  • 我使用了您所描述的上述方法。但它正在获取所有用户名的笛卡尔结果,其中 DOB 包含第 8 个月(当前月份)的记录和日期为 29 日(当前系统日期)的 DOB。就像所有 DOB 为 8 月但不同日期即将到来的用户,以及所有 DOB 为 29th(当前)但不同月份的用户。
猜你喜欢
  • 2017-12-15
  • 2016-06-15
  • 2021-04-23
  • 2016-01-23
  • 2019-03-05
  • 1970-01-01
  • 2020-08-21
  • 1970-01-01
  • 2015-05-13
相关资源
最近更新 更多