当前位置:  开发笔记 > 编程语言 > 正文

在遵循数据库第一种方法时,使用[NotMapped]将其他信息传递给视图

如何解决《在遵循数据库第一种方法时,使用[NotMapped]将其他信息传递给视图》经验,为你挑选了1个好方法。

我正在使用asp.net mvc-5 Web应用程序,我正在使用实体框架5.0.我已经映射了我创建.edmx文件的SQL服务器数据库表.现在我想扩展模型类以获得额外的非数据库属性,所以我为我的模型类创建了一个部分类,我提供了一个额外的属性如下: -

using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Linq;
using System.Web;

namespace Test.Models
{

    public partial class User
    {
         [NotMapped]
         public string NonDataBaseColumn { set; get; }
    }
}

所以我有这些问题:

    这是通过在分部类中定义其他列来传递其他属性的有效方法.

    因为我使用数据库第一种方法,所以我需要添加[NotMapped]数据注释,还是[NotMapped]仅在遵循代码优先方法时才有效?

    在任何情况下都可以自动在数据库中创建NotMapped列(在我的情况下是NonDataBaseColumn)?

CodeCaster.. 6

这是通过在分部类中定义其他列来传递其他属性的有效方法吗?

技术上它是,但在我之后重复:不要使用Entity Framework模型作为MVC视图模型,并传播这个词.

我仍然不明白为什么几乎每个教程都会显示出这种可怕的做法,这种做法每天产生二十多个这样的问题,但这不是应该做的.域模型不是视图模型.

那些教程可能就是这样做的,因为它对于"我的第一个TODO WebApp"来说非常好用,所以它们可以显示较少的代码和较少的良好开发实践来解释,当它因为任何比这更复杂的事情而可怕地破坏时,你就会陷入困境.

例如,尝试向SelectList实体添加属性以提供数据下拉列表,然后将数据层提取到DAL库中,并且想知道为什么必须从DAL引用MVC.

另请参阅:ASP.NET MVC:使用EF实体作为视图模型?

至于你对[NotMapped]属性的问题:它确切地说明了它的名称和文档状态,它导致它应用的属性不被映射到数据库列.



1> CodeCaster..:

这是通过在分部类中定义其他列来传递其他属性的有效方法吗?

技术上它是,但在我之后重复:不要使用Entity Framework模型作为MVC视图模型,并传播这个词.

我仍然不明白为什么几乎每个教程都会显示出这种可怕的做法,这种做法每天产生二十多个这样的问题,但这不是应该做的.域模型不是视图模型.

那些教程可能就是这样做的,因为它对于"我的第一个TODO WebApp"来说非常好用,所以它们可以显示较少的代码和较少的良好开发实践来解释,当它因为任何比这更复杂的事情而可怕地破坏时,你就会陷入困境.

例如,尝试向SelectList实体添加属性以提供数据下拉列表,然后将数据层提取到DAL库中,并且想知道为什么必须从DAL引用MVC.

另请参阅:ASP.NET MVC:使用EF实体作为视图模型?

至于你对[NotMapped]属性的问题:它确切地说明了它的名称和文档状态,它导致它应用的属性不被映射到数据库列.

推荐阅读
勤奋的瞌睡猪_715
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有