首页 > 解决方案 > 具有 LINQ 查询的实体框架重复记录

问题描述

使用实体框架 6.0 和 .Net 4.5。使用实体数据模型向导和表数据映射表[Log]以设置数据连接,如下所示:

时间戳 所有者 信息 温顺的
06-11-2020 10:32:49 用户 1 消息-1 100
06-11-2020 10:32:49 用户 1 消息 2 100
06-11-2020 10:32:50 行政人员 100
06-11-2020 10:32:50 行政人员 100
06-11-2020 10:32:49 用户 1 消息 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 语句。任何人都可以提出解决方案,这个问题的根本原因是什么?

注意:我在表结构中没有任何主键或任何类型的约束。

问候, 苏雷什考希克

标签: c#entity-framework-6

解决方案


推荐阅读