ASP.NET Entity Framework 6 HashSet 或 List 的集合?
Posted
技术标签:
【中文标题】ASP.NET Entity Framework 6 HashSet 或 List 的集合?【英文标题】:ASP.NET Entity Framework 6 HashSet or List for a collection? 【发布时间】:2015-04-24 16:13:46 【问题描述】:我的 EF 模型如下所示:
public class ContentStatus
public ContentStatus()
this.Contents = new List<Content>();
public int ContentStatusId get; set;
public string Name get; set;
public virtual ICollection<Content> Contents get; set;
但是我也看到了这样的实现:
public class ContentStatus
public ContentStatus()
this.Contents = new HashSet<Content>();
public int ContentStatusId get; set;
public string Name get; set;
public virtual ICollection<Content> Contents get; set;
这是此对象的 DDL:
CREATE TABLE [dbo].[ContentStatus] (
[ContentStatusId] INT NOT NULL,
[Name] NVARCHAR (50) NOT NULL,
CONSTRAINT [PK_ContentStatus] PRIMARY KEY CLUSTERED ([ContentStatusId] ASC)
);
谁能告诉我应该使用哪个,甚至有区别,我什么时候使用 List 以及 HashSet 如果适用的话。
谢谢
【问题讨论】:
【参考方案1】:这取决于您的用例,但在大多数情况下,您只能将一个项目添加到集合中一次,因为例如每个状态只应用于一个内容一次。我怀疑你可以让一个内容在一个状态中出现两次。因此 HashSet 是正确的数据结构,因为它可以防止重复。如果一个项目可以重复,List 是正确的,但我在实践中没有遇到这种情况,甚至不知道 EF 会如何处理它。
作为旁注,我建议您不要在实体中包含项目集合,除非您需要它。例如,如果您正在构建一个 Web 应用程序来列出产品,您可能有一个视图,您可以在其中显示单个产品及其标签。因此,产品应该有一个标签的集合,以使这种情况变得容易。但是,您可能没有显示标签及其产品集合的页面,因此标签不应具有 Products 属性。它只是不关心相关产品。看来这个 Status 实体并不关心它的 Contents 集合。
【讨论】:
【参考方案2】:所以HashSet<T>
是definition
而List<T>
没有这些功能。
所以我想这取决于所需的特性和性能(在小型设备上可以忽略不计)。它们都可以枚举。
性能(尽管可能存在微小差异)将在读取和写入两部分中表现出来。正如 Sean 评论的那样,由于哈希码计算和唯一性比较,写入可能会受到惩罚。但是读取速度非常快 (o(1)
)。
真的,这完全取决于所需的特性。
在我的项目中,我会使用List<T>
,但这是我的惯例。您可以确定自己的约定,只要您坚持。
【讨论】:
HashSet
可以迭代。任何实现IEnumerable
的类都可以,List<T>
和HashSet<T>
都可以实现它。
我会假设 Hashset 的插入成本更高,因为它确保唯一性,因此必须与其他条目或至少它们的哈希进行比较,但删除成本更低(假设哈希找到项目的速度比枚举列表会做)。
@SeanB 是的,但与小数据集无关。前几天晚上我正在测量数组和哈希集的性能,对于 2000 个项目,我必须以刻度为单位进行测量,以查看一些数字(毫秒不够小)
@CallumLinington,公平点,但是你的答案是性能是决定因素的结论是没有实际意义的。
@SeanB 是的,这个答案似乎更像是对该方法的一般答案(我在一年前做过)。以上是关于ASP.NET Entity Framework 6 HashSet 或 List 的集合?的主要内容,如果未能解决你的问题,请参考以下文章
在 ASP.NET Core 中使用 Entity Framework 6
ASP.NET Entity Framework 6 HashSet 或 List 的集合?
浅谈最新beta版ASP.NET 5架构Entity Framework 7预览版
如何在 ASP.NET 5 中将 Entity Framework 6 与 MySQL 一起使用?