我正在尝试创建我的第一个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'的元数据或 在模型生成期间检测到更多验证错误:
实体类型用户没有防御密钥。
我的模型名称是否需要与我的表名完全匹配?
答案 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之外,还要将正确的连接字符串添加到配置文件中。我希望这会有所帮助。
由于