ChatGPT解决这个技术问题 Extra ChatGPT

忽略 Entity Framework 4.1 Code First 中的类属性

我的理解是,[NotMapped] 属性在当前处于 CTP 的 EF 5 之前不可用,因此我们无法在生产中使用它。

如何将 EF 4.1 中的属性标记为被忽略?

更新:我发现了一些奇怪的东西。我得到了 [NotMapped] 属性,但由于某种原因,EF 4.1 仍会在数据库中创建一个名为 Disposed 的列,即使 public bool Disposed { get; private set; } 标记为 [NotMapped]。该类当然实现了IDisposeable,但我不明白这应该有什么关系。有什么想法吗?

在我看来,它也应该适用于 Entity Framework 4.1。检查此链接:social.msdn.microsoft.com/Forums/eu/adodotnetentityframework/…
@SamLeach:我在发布自己的问题之前已经阅读了该问题,但没有找到解决方案。问题是如何在 EF4 中实现相同的功能?我在那篇文章中遗漏了什么吗?
这也是我的想法,因为我有 EF 4.1 并且可以看到该属性。但 EF 似乎很乐意在我的应用程序中完全忽略它。对于本机和引用类型以及 com 引用类型(例如 MS office intrerop 应用程序)都是如此。
对不起,我现在用一个简单的应用程序做了一个测试,它可以工作。你能提供示例代码吗?

C
Community

您可以使用 NotMapped 属性数据注释来指示 Code-First 排除特定属性

public class Customer
{
    public int CustomerID { set; get; }
    public string FirstName { set; get; } 
    public string LastName{ set; get; } 
    [NotMapped]
    public int Age { set; get; }
}

[NotMapped] 属性包含在 System.ComponentModel.DataAnnotations 命名空间中。

您也可以使用 DBContext 类中的 Fluent API 覆盖 OnModelCreating 函数来执行此操作:

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
   modelBuilder.Entity<Customer>().Ignore(t => t.LastName);
   base.OnModelCreating(modelBuilder);
}

http://msdn.microsoft.com/en-us/library/hh295847(v=vs.103).aspx

我检查的版本是 EF 4.3,这是您使用 NuGet 时可用的最新稳定版本。

编辑:2017 年 9 月

ASP.NET Core(2.0)

数据标注

如果您使用的是 asp.net core(撰写本文时为 2.0),则可以在属性级别使用 [NotMapped] 属性。

public class Customer
{
    public int Id { set; get; }
    public string FirstName { set; get; } 
    public string LastName { set; get; } 
    [NotMapped]
    public int FullName { set; get; }
}

流畅的 API

public class SchoolContext : DbContext
{
    public SchoolContext(DbContextOptions<SchoolContext> options) : base(options)
    {
    }
    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        modelBuilder.Entity<Customer>().Ignore(t => t.FullName);
        base.OnModelCreating(modelBuilder);
    }
    public DbSet<Customer> Customers { get; set; }
}

谢谢。看到背后付出努力的答案总是件好事。在将另一个答案标记为正确之前,我实际上并没有注意到您的最后一行。由于您的答案之前确实出现过,我认为将您的答案改正是公平的。我相信@ilmatte 不会介意的。
使用 EF 的 v5 > 这些现在存在于 System.ComponentModel.DataAnnotations.Schema
当我使用 FluentMApping 时,该字段仍会在结果集中返回,尽管知道它为 NULL。我怎样才能让它甚至不被退回?
使用 [NotMapped] 还会告诉其他序列化程序(例如 JSON / XML)不要映射此属性。如果您只想阻止映射到数据库表,但仍然让序列化程序访问该属性,则必须使用 OnModelCreating 方法。
虽然我还没有完全弄清楚如何,但这不适用于实体框架 6+ 上继承的属性,属性和流利的 api 似乎忽略了指令
S
Shane Kenyon

从 EF 5.0 开始,您需要包含 System.ComponentModel.DataAnnotations.Schema 命名空间。


现在还是这样吗?我正在使用 EF 6.0,至少我的项目不再是这种情况。除非我引用了一个名称空间,该名称空间已经在某处引用了上述内容。