mysql - EF6为MySql数据库生成日期比较sql

标签 mysql linq date entity-framework-6 compare

我有一个内置于 .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/

相关文章:

mysql - 如何在不使用 UNION 的情况下编写此 MYSQL 查询?

java - 为什么日期转换会返回不同的时间戳?

java - 需要帮助将字符串解析为日期

mysql - 良好的登录系统数据库设计的唯一约束 ID?

python - SQL 一对多关系 - 查询以检索 JSON 格式的数据

php - 如何在 php mysql 中存储 javascript 复选框结果

c#:带有多个条件的字典的 Linq

.net - LINQ to SQL 左外连接

C# 将 XML 值加载到字典中,名称作为索引

linux - 合并行并执行日期操作