Cannot insert duplicate key in object 'dbo.User'.\r\nThe statement has been terminated

前端 未结 1 890
太阳男子
太阳男子 2020-12-30 01:11

I have a user table. there are references to this table from other tables for fields such as CreatedBy.

Problem is, when I am inserting a row of another table (say \

相关标签:
1条回答
  • 2020-12-30 01:57

    You can insert an entity together with related entities or you can insert an entity without the related entities, just referencing existing ones. It depends on the code you write.

    Example 1:

    User user = GetUserFromSomewhere();
    using (var context = new MyContext())
    {
        Order order = new Order();
        order.CreatedBy = user;
    
        context.Orders.AddObject(order);
        // will put both order and related entity user into Added state
        // because user is not attached to the context
    
        context.SaveChanges();
        // creates new order and new user and sets the relationship between them
    }
    

    Example 2:

    using (var context = new MyContext())
    {
        User user = context.Users.SingleOrDefault(u => u.Id == 1);
        // query attaches this user to this context
        // user is in state Unchanged now
    
        Order order = new Order();
        order.CreatedBy = user;
    
        context.Orders.AddObject(order);
        // will put the order into Added state but doesn't touch the
        // state of already attached related entities -> user remains
        // in state Unchanged
    
        context.SaveChanges();
        // creates new order with reference to user, but doesn't create new user
    }
    

    Example 3:

    User user = GetUserFromSomewhere();
    using (var context = new MyContext())
    {
        context.Users.Attach(user);
        // we attach explicitely to the context telling EF thereby
        // that we know that this user exists in the DB
        // user is in state Unchanged now
    
        Order order = new Order();
        order.CreatedBy = user;
    
        context.Orders.AddObject(order);
        // will put the order into Added state but doesn't touch the
        // state of already attached related entities -> user remains
        // in state Unchanged
    
        context.SaveChanges();
        // creates new order with reference to user, but doesn't create new user
    }
    

    Edit

    Example 4:

    int userId = GetUserIdFromSomewhere();
    using (var context = new MyContext())
    {
        var user = new User { Id = userId };
        // we create a stub user entity with the correct primary key
        // It's not necessary to set other properties
        // to only set the relationship to the order
    
        context.Users.Attach(user);
        // we attach explicitely to the context telling EF thereby
        // that we know that this user exists in the DB
        // user is in state Unchanged now
    
        Order order = new Order();
        order.CreatedBy = user;
    
        context.Orders.AddObject(order);
        // will put the order into Added state but doesn't touch the
        // state of already attached related entities -> user remains
        // in state Unchanged
    
        context.SaveChanges();
        // creates new order with reference to user, but doesn't create new user
    }
    
    0 讨论(0)
提交回复
热议问题