計算資料行是一個虛擬資料行,除非資料行標示了PERSISTED,否則,並未實際儲存在資料表中。
data:image/s3,"s3://crabby-images/3d681/3d681b766ec742135013b2322a81b80f40e19fc7" alt=""
Entity
public class Test : FullAuditedAggregateRoot<Guid>
{
public virtual int Total{ get; set; }
public virtual int Used { get; set; }
public virtual int Unused { get; private set; }
}
DbContext
虛擬資料行
modelBuilder.Entity<Test>()
.Property(p => p.Unused)
.HasComputedColumnSql("([Total] - [Used])");
實際上不儲存該值,每次要用的時候即時運算出該欄位
實值資料行
modelBuilder.Entity<Test>()
.Property(p => p.Unused)
.HasComputedColumnSql("([Total] - [Used])", stored: true);
每次更新時重新計算,並將結果作為值寫入資料庫
參照
Generated Values - EF Core | Microsoft Learn
延伸
ABP.IO WEB應用程式框架 取得關聯資料 | 御用小本本 - 點部落 (dotblogs.com.tw)
data:image/s3,"s3://crabby-images/a60dd/a60dd253910b03da99eec726cbd3f4ff796c62fa" alt=""