【问题标题】:Entity Framework auto generate primary key实体框架自动生成主键
【发布时间】: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


【解决方案1】:

您必须将User 类中的属性更改为:

数据注释:

 [System.ComponentModel.DataAnnotations.Schema.DatabaseGenerat‌ed(System.ComponentM‌​odel.DataAnnotations‌​.Schema.DatabaseGeneratedOp‌​tion.None)]
 public int UserId { get; set; }

或 Fluent API:

modelBuilder.Entity<User>().Property(m => m.UserId)
         .HasDatabaseGeneratedOption(DatabaseGeneratedOption.None);

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-05-20
    相关资源
    最近更新 更多