EntityFrameworkCore 中的 Attach 方法

Attach 的坑

ModelFiledDatabase ValueConsole Value
UserPhone+123000000000+12333333333
UserEmailnulleeeeeee
UserId11
dbcontext.Users.Add(new User()
    {
        UserName = "test1",
        CreatedAt = DateTime.Now
        Phone = "+1230000000"
    });
dbcontext.SaveChanges();

var user = new User()
{
    Id = 1,
    Phone = "+12333333333",
    Email = "eeeeeeee"
};
dbcontext.Users.Attach(user); 
//上面语句会抛异常,原因是dbcontext 已经跟踪了一个相同Id的实体,所以使用Attach注意当前的上下文

var user = new User()
{
    Id = 1,
    Phone = "+12333333333",
    Email = "eeeeeeee",
    UpdatedAt = DateTime.Now
};
var entryEntity = dbContext.Users.Attach(user1);

//entryEntity.State = EntityState.Unchanged; 有没有这句话结果是一样的
entryEntity.Property(p => p.Phone).IsModified = true;
entryEntity.Property(p => p.Email).IsModified = false;
dbContext.SaveChanges();

//数据库中只有明确标为`IsModified`为`true`的 `Phone`的值更改了,其余值保持不变

var item = dbContext.Users.FirstAsync().Result;
//item 的值和 user 中值完全相同 
var user = new User()
{
    Id = 1,
    Phone = "+12333333333",
    Email = "eeeeeeee",
    UpdatedAt = DateTime.Now
};
var entryEntity = dbContext.Users.Attach(user1);

entryEntity.State = EntityState.Modified;
entryEntity.Property(p => p.Phone).IsModified = true;
entryEntity.Property(p => p.Email).IsModified = false;
dbContext.SaveChanges();

//数据库中只有明确标为`IsModified`为`false`的 `Emial`的值没有更改,其余值都会做更改

var item = dbContext.Users.FirstAsync().Result;
//item 的值和 user 中值完全相同 
var user = dbContext.Users.FirstAsync().Result;
var userTemp = new User { Id = 1 };
dbContext.Users.Attach(userTemp);
//报异常,原因同例1
var user = dbContext.Users.AsNoTracking().FirstAsync().Result;
var userTemp = new User { Id = 1 };
dbContext.Users.Attach(userTemp);
//不报异常

转载于:https://www.cnblogs.com/ArvinZhao/p/10844559.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值