如何解决带有 LINQ 查询的实体框架重复记录
使用实体框架 6.0 和 .Net 4.5。使用实体数据模型向导和表数据映射表 [Log]
以设置数据连接,如下所示:
时间戳 | 所有者 | 留言 | docid |
---|---|---|---|
06-11-2020 10:32:49 | 用户 1 | message-1 | 100 |
06-11-2020 10:32:49 | 用户 1 | message-2 | 100 |
06-11-2020 10:32:50 | 管理员 | 100 | |
06-11-2020 10:32:50 | 管理员 | 100 | |
06-11-2020 10:32:49 | 用户 1 | message-3 | 100 |
当我在 sql Server Management Studio 中运行查询时,它返回正确的结果:
SELECT *
FROM [dbo].[Log]
WHERE docid = 100
但是当我使用以下查询在源代码中使用实体框架进行查询时,它会重复具有相同时间戳的行:
var logEntries = (
from logEty in context.Log
where logEty.docid == 100
orderby logEty.timestamp
select logEty
)
.ToList();
foreach (var entry in logEntries)
{
message = entry.message;
Console.WriteLine(message);
message = string.Empty;
}
输出:
message-1
message-1
message-1
我的问题是为什么我在结果中得到重复的记录。甚至我删除了 sort by 语句。任何人都可以提出解决方案以及此问题的根本原因是什么?
注意:我在表结构中没有任何主键或任何类型的约束。
问候, 苏雷什·考希克
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。