Abp Vnext 中的UpdateAsync

今天来说一下abp vnext 中UpdateAsync 不能修改(锁的问题),查看执行sql 发现 where 后面不仅有Id= 还有 and ConcurrencyStamp=,所以不能修改,要想修改就得先获取再修改,这有什么意义呢?其实这个就在于如下配置,获取就有意义了,获取对象后就给表的行加了锁(进程内),其他人就无法修改,ConcurrencyStamp每次修改完都会变动,所以,页面上如果获取的不是最新的就无法修改

Check.NotNull(builder, nameof(builder));
            builder.Entity<AccountNo>(b=> {
                b.ToTable(ExamplesConsts.DbTablePrefix+"AccountNo");
                b.ConfigureByConvention();
                b.Property(x => x.ConcurrencyStamp).IsConcurrencyToken(); 如果配置了他
            });

而且线程中不能存在俩个AccountNo对象,如果有俩个对象修改也会失败

//var e = ObjectMapper.Map<AccountNoDto, AccountNo>(dto);
                var xxx= await _repo.GetAsync(t=>t.Id.Equals(dto.Id));
                //e.ConcurrencyStamp = xxx.ConcurrencyStamp;
                //await _repo.DeleteAsync(x => x.Id.Equals(dto.Id)) ;
                xxx.UserName = dto.UserName;
                xxx.Password = dto.Password;
                var rlt = await _repo.UpdateAsync(xxx);
                dto = ObjectMapper.Map<AccountNo, AccountNoDto>(rlt);

如上代码,如果使用automap映射的对象去修改就会报错应为这个时候AccountNo对象不唯一,修改如上使用获取到的对象,进行修改,就没有问题了,如果不设置b.Property(x => x.ConcurrencyStamp).IsConcurrencyToken()怎么使用都行,只要有ConcurrencyStamp和数据库的值一样就行

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值