我有一个内置于 .NETCore 2.1 的 Web 应用程序,它调用内置于 .Net 4.6 的 API。 API 调用使用 Entity Framework 6 的服务层。我正在连接到 MySql 数据库。我正在使用 Pomelo.EntityFrameworkCore.MySql 连接器。当使用 LINQ 查询根据日期比较获取记录时,EF6 似乎将日期比较为字符串文字。
我尝试了 LINQ 查询的所有不同类型的变体,并在线查找了进行日期比较的扩展库,但没有结果
这是 LINQ 查询
int year = DateTime.Now.Year;
DateTime firstDayOfYear = new DateTime(year, 1, 1);
DateTime lastDayOfYear = new DateTime(year, 12, 31);
var startDate = firstDayOfYear.AddYears(-2);
var endDate = lastDayOfYear.AddYears(-1);
var company = dbContext.Companies.Where(c =>
c.Updating &&
c.UpdatedBy == username &&
c.LastUpdate > startDate &&
c.LastUpdate < endDate)
.FirstOrDefault();
这是生成的 SQL 的一部分。请注意日期值之前的 @ 符号
`Extent2`.`ID` AS `ID1`,
`Extent2`.`Name` AS `Name1`
FROM Company AS `Extent1` INNER JOIN `Table_2` AS `Extent2` ON `Extent1`.`ID` = `Extent2`.`ID`
WHERE ((((`Extent1`.`SomeFlag` != 1) AND (`Extent1`.`LastUpdate` > @'01/01/2017 00:00:00')) AND (`Extent1`.`LastUpdate` < @'31/12/2017 00:00:00')) AND ((`Extent1`.`ID` IN ( '1','2','6','7','8' )) AND (`Extent1`.`ID` IS NOT NULL))) AND (NOT ((`Extent1`.`Telephone` IS NULL) OR ((LENGTH(`Extent1`.`Telephone`)) = 0)))) AS `Project1`
在 MySql 工作台中手动运行 sql 查询不会返回任何行。如果我删除 @ 符号,它确实会按预期返回行。我做错了什么?
最佳答案
我无法弄清楚为什么 EF 会以这种方式转换 LINQ,因此我只是使用存储过程调用来绕过它。至少这样我可以自己编写 SQL。
int year = DateTime.Now.Year;
DateTime firstDayOfYear = new DateTime(year, 1, 1);
DateTime lastDayOfYear = new DateTime(year, 12, 31);
var startDate = firstDayOfYear.AddYears(QueueConfig.UpdateQueueStartDateInYears);
var endDate = lastDayOfYear.AddYears(QueueConfig.UpdateQueueStartDateInYears);
var userParam = new MySql.Data.MySqlClient.MySqlParameter("userName", username);
var sdParam = new MySql.Data.MySqlClient.MySqlParameter("startDate", startDate);
var edParam = new MySql.Data.MySqlClient.MySqlParameter("endDate", endDate);
var lockedCompany = dbContext.Database.SqlQuery<CompanyDto>("CALL GetLockedCompany(@userName,@startDate,@endDate)", userParam, sdParam, edParam);
var companyDto = lockedCompany.SingleOrDefault();
关于mysql - EF6为MySql数据库生成日期比较sql,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57257074/