添加控制器时无法获取元数据mvc4

时间:2012-08-14 04:03:14

标签: c# asp.net-mvc entity-framework

我正在尝试创建我的第一个mvc类,并且我遇到了一个问题。 我在我的主机帐户上使用共享数据库并创建了以下类

namespace MvcApplication2.Models
{
    public class tUsers
    {

            public int UserID { get; set; }
            public string Username { get; set; }
            public string UserEmail { get; set; }
            public string UserPassword { get; set; }
            public int GroupId { get; set; }


    }

    public class tUsersDBContext : DbContext
    {
        public DbSet<tUsers> tUsers { get; set; }
    }
}

这是我的连接字符串

   <add name="DefaultConnection" connectionString="Data Source=gdfgdfgdfg;Initial Catalog=fsdf_fdsf;Persist Security Info=True;User ID=ddd_reddntal;Password=fgfggfdg" providerName="System.Data.SqlClient" />

我得到的错误是

  

无法检索'mvcapplication2.models.tusers'的元数据或   在模型生成期间检测到更多验证错误:

     

实体类型用户没有防御密钥。

我的模型名称是否需要与我的表名完全匹配?

2 个答案:

答案 0 :(得分:5)

实体框架无法识别tUsers类的主键属性。使用UserID属性注释Key属性。如果您的表名与类名不同,请使用Table属性指定表名。

尝试对类名使用正确的命名约定。在这种情况下,它应该是User而不是tUsers

[Table("MyTableName")]
public class tUsers
{       
        [Key]
        public int UserID { get; set; }
        public string Username { get; set; }
        public string UserEmail { get; set; }
        public string UserPassword { get; set; }
        public int GroupId { get; set; }
}

答案 1 :(得分:0)

请确保您已在表中将Id定义为主键,并确保您已为模型类正确定义属性。另外,除了应用程序提供的DefaultConnection之外,还要将正确的连接字符串添加到配置文件中。我希望这会有所帮助。

由于