【发布时间】:2016-12-22 07:49:42
【问题描述】:
我是实体框架的新手。我有一个简单的类:
public class User
{
[System.ComponentModel.DataAnnotations.Schema.DatabaseGenerated(System.ComponentModel.DataAnnotations.Schema.DatabaseGeneratedOption.Identity)]
public int UserId { get; set; }
public string Email { get; set; }
public string UserName { get; set; }
public string Password { get; set; }
//public UserList Users { get; set; }
public User() { }
public User(int userId, string email, string username)
{
UserId = userId;
Email = email;
UserName = username;
}
}
还有我的初始化器类:
public class UserDataInitializer : DropCreateDatabaseAlways<UserDataContext>
{
protected override void Seed(UserDataContext context)
{
var Users = new List<User> {
new User() {UserId=1, Email="a1@gmail.com", UserName="a1", Password="123456"},
new User() {UserId=2, Email="a2@gmail.com", UserName="a2", Password="123456"},
new User() {UserId=3, Email="a3@gmail.com", UserName="a3", Password="123456"},
new User() {UserId=4, Email="a4@gmail.com", UserName="a4", Password="123456"}}
Users.ForEach(i => context.Users.Add(i));
context.SaveChanges();
}
}
假设,我想添加 UserId=100 的新用户。它会自动将 UserId 更改为 5。
如何禁用对 EF 的修改? 'UserId' 必须为主键且类型为 int。
【问题讨论】:
-
在 UserId
[System.ComponentModel.DataAnnotations.DatabaseGenerated(System.ComponentModel.DataAnnotations.DatabaseGeneratedOption.None)]上使用。 -
@M.Wiśnicki 谢谢!
标签: c# entity-framework