Entity Framework Core 生成跟踪列-阴影属性
摘自:https://www.cnblogs.com/tdfblog/p/entity-framework-core-generate-tracking-columns.html
Ef Core 官方文档: https://docs.microsoft.com/zh-cn/ef/core/
文章列举了三种:读写属性、只读属性、不定义属性(阴影属性 Shadow )。
下面是摘的一种阴影属性简单实现:
一、添加阴影属性:
1. 在 OnModelCreating 方法中声明阴影属性:
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.AddAuditableShadowProperties();
base.OnModelCreating(modelBuilder);
}
2. 这里是 AddAuditableShadowProperties 实现:
public static readonly string CreatedByUserId = nameof(CreatedByUserId);
public static readonly string ModifiedByUserId = nameof(ModifiedByUserId);
public static readonly string CreatedDateTime = nameof(CreatedDateTime);
public static readonly string ModifiedDateTime = nameof(ModifiedDateTime);
public static void AddAuditableShadowProperties(this ModelBuilder modelBuilder)
{
var models = modelBuilder.Model
.GetEntityTypes()
.Where(e => typeof(IEntityBase).IsAssignableFrom(e.ClrType));
foreach (var entityType in models)
{
modelBuilder.Entity(entityType.ClrType)
.Property<long?>(CreatedByUserId);
modelBuilder.Entity(entityType.ClrType)
.Property<long?>(ModifiedByUserId);
modelBuilder.Entity(entityType.ClrType)
.Property<DateTimeOffset?>(CreatedDateTime);
modelBuilder.Entity(entityType.ClrType)
.Property<DateTimeOffset?>(ModifiedDateTime);
}
}
二、修改阴影属性:
1. 重写 SaveChange 方法:
public override int SaveChanges()
{
ChangeTracker.DetectChanges();
//保存之前修改阴影属性
SetShadowProperties();
// for performance reasons, to avoid calling DetectChanges() again.
ChangeTracker.AutoDetectChangesEnabled = false;
var result = base.SaveChanges();
ChangeTracker.AutoDetectChangesEnabled = true;
return result;
}
private void SetShadowProperties()
{
// we can't use constructor injection anymore, because we are using the `AddDbContextPool<>`
var httpContextAccessor = this.GetService<IHttpContextAccessor>();
ChangeTracker.SetAuditableEntityPropertyValues(httpContextAccessor);
}
2. 修改阴影属性:
public static void SetAuditableEntityPropertyValues(this ChangeTracker changeTracker, IHttpContextAccessor httpContextAccessor)
{
var httpContext = httpContextAccessor?.HttpContext;
// var userAgent = httpContext?.Request?.Headers["User-Agent"].ToString();
// var userIp = httpContext?.Connection?.RemoteIpAddress?.ToString();
var now = DateTimeOffset.Now;
var modifiedEntries = changeTracker.Entries<IEntityBase>().Where(x => x.State == EntityState.Modified);
foreach (var modifiedEntry in modifiedEntries)
{
modifiedEntry.Property(ModifiedDateTime).CurrentValue = now;
modifiedEntry.Property(ModifiedByUserId).CurrentValue = ;
}
var addedEntries = changeTracker.Entries<IEntityBase>().Where(x => x.State == EntityState.Added);
foreach (var addedEntry in addedEntries)
{
addedEntry.Property(CreatedDateTime).CurrentValue = now;
addedEntry.Property(CreatedByUserId).CurrentValue = ;
}
}
Entity Framework Core 生成跟踪列-阴影属性的更多相关文章
- Entity Framework Core 生成跟踪列
本文翻译自<Entity Framework Core: Generate tracking columns>,由于水平有限,故无法保证翻译完全正确,欢迎指出错误.谢谢! 注意:我使用的是 ...
- Entity Framework Core生成的存储过程在MySQL中需要进行处理及PMC中的常用命令
在使用Entity Framework Core生成MySQL数据库脚本,对于生成的存储过程,在执行的过程中出现错误,需要在存储过程前面添加 delimiter // 附:可以使用Visual Stu ...
- entity framework core 生成 postgresql 数据库实体
.net core 2.0 使用db first 方式生成 表 和context PM 控制台运行命令出错 Scaffold-DbContext "Host=localhost;Databa ...
- 被Entity Framework Core的细节改进震撼了一下
今天用 SQL Server Profiler 查看 Entity Framework Core 生成的 SQL 语句时,突然发现一个细节改进,并且被它震撼了一下: exec sp_executesq ...
- Entity Framework Core Code First 项目实践
Entity Framework Core Code First 实践 任何一种技术的出现都是为了解决一系列特定的问题,只有了解了技术所要解决的关键问题,才能理解它的真正用途,之后,才能在实践中用好它 ...
- Entity Framework Core 使用HiLo生成主键
#cnblogs_post_body.cnblogs-markdown p img { max-width: 95%; } HiLo是在NHiernate中生成主键的一种方式,不过现在我们可以在Ent ...
- 对Entity Framework Core的一次误会:实体状态不跟踪
在 Entity Framework 中,当通过 EF 使用 LINQ 查询获取到一个实体(实际得到的是 EF 动态生成的实体类的代理类的实例)时,这个实体的状态默认是被跟踪的.所以,当你修改实体的某 ...
- Entity Framework Core 1.1 Preview 1 简介
实体框架核心(EF Core)是Entity Framework的一个轻量级,可扩展和跨平台版本. 10月25日,Entity Framework Core 1.1 Preview 1发布了. 升级到 ...
- Working with Data » Getting started with ASP.NET Core and Entity Framework Core using Visual Studio » 读取关系数据
Reading related data¶ 9 of 9 people found this helpful The Contoso University sample web application ...
随机推荐
- maven下载的jar相应pom文件下载不完整问题。
今天遇到一个奇葩问题: 同样的项目,我启动报错 : 某个class文件找不到.. 查找maven 依赖也的确没有找到 对应的jar 包. 查找同事项目,可以看到该class对应的 jar 包 是 lo ...
- vb中去掉string数组的一部分
今天碰到一个问题,登陆的时候,如果不需要验证手机号为空,则不去验证手机号 因为登陆的时候所有的验证信息都存放在一个数组里 Dim CheckUserInfo() As String ={UserBir ...
- ubuntu14简介/安装/菜鸟使用手册
Linux拥有众多的发行版,可以分为两大类商业版和开源社区免费版.商业版以Radhat为代表,开源社区版以debian为代表. 简单的比较ubuntu与centos. Ubuntu 优点:丰富的 ...
- TCP与UDP传输协议
目录结构: contents structure [-] 1 TCP协议和UDP协议的比较 1.1 TCP协议 TCP的全称是Transmission Control Protocol (传输控制协议 ...
- 开发简单的JavaWeb项目
一.配置相关环境 下载配置JDK,eclipse,Tomcat服务器,Mysql数据库,Navicat for MySQL(数据库可视化工具) 如果你已经做好各个环境的配置,eclipse与Tomca ...
- 2018.12.31 bzoj4001: [TJOI2015]概率论(生成函数)
传送门 生成函数好题. 题意简述:求nnn个点的树的叶子数期望值. 思路: 考虑fnf_nfn表示nnn个节点的树的数量. 所以有递推式f0=1,fn=∑i=0n−1fifn−1−i(n>0) ...
- 2018.11.08 NOIP模拟 景点(倍增+矩阵快速幂优化dp)
传送门 首先按照题意构造出转移矩阵. 然后可以矩阵快速幂求出答案. 但是直接做是O(n3qlogm)O(n^3qlogm)O(n3qlogm)的会TTT掉. 观察要求的东西发现我们只关系一行的答案. ...
- android 应用商店
下面更多 http://wiki.youmi.net/Wiki/PromotionChannelIDs 小米 http://market.xiaomi.com/dev安智市场 http://dev.a ...
- ACM-ICPC 2018 徐州赛区网络预赛 B BE, GE or NE(博弈,记忆化搜索)
链接https://nanti.jisuanke.com/t/31454 思路 开始没读懂题,也没注意看数据范围(1000*200的状态,记忆化搜索随便搞) 用记忆化搜索处理出来每个状态的胜负情况 因 ...
- js读取后端写入cookie出现乱码
设置字符编码集即可 Cookie cookie = new Cookie("user",URLEncoder.encode(nMessage, "UTF-8") ...