今天来说一下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
和数据库的值一样就行