Audit History,常被用来记录record的日常操作信息,包括创建,更新,删除。这是一个非常实用的功能,想想看,如果数据被误修改了,通过Audit History,可以很容易地找到修改前的数据值,然后还原回来;不仅如此,如果数据有异常,也可以通过Audit History,看看数据是由谁在什么时候给修改了。

  关于如何开启Audit,以及如何自定义配置Auditing,这里不再多赘述,这些基础操作都在Settings -> Auditing 里,网上也有不少这方面的介绍

  这里着重想说的,是在误删了数据之后,如何借用Audit功能,还原数据。

  一般情况下,我们查看数据的Audit信息,是通过具体record的Audit History。

  但是如果这条record已经被删除了呢,上面的操作就行不通了。

  这个时候,可以看第一张截图,里面有个Audit Summary View。在这里,我们将会有所发现。

  这里是其中的一条删除的相关记录,可以看到,最后的操作是Delete。

  如果你打开这条操作记录,里面会显示这条记录在删除前的字段信息,以及是谁在什么时候,执行了删除操作。

  现在,我们已经有了这条删除操作的记录,那么如何还原这条记录,大致的思路也就很清晰了:

  1. 获取Audit操作记录

  2. 根据Audit中待还原记录的字段信息,还原数据

  下面是具体的代码实现:

//获取所有的相关的Audit记录
var auditrecords = service.RetrieveMultiple(new FetchExpression(fetchXML));
foreach (Entityaudit in auditrecords.Entities)
{
//根据Audit Id查询Audit Details
RetrieveAuditDetailsRequest auditDetailsRequest = new RetrieveAuditDetailsRequest();
auditDetailsRequest.AuditId = audit.Id;
RetrieveAuditDetailsResponseauditDetailsResponse =
(RetrieveAuditDetailsResponse)service.Execute(auditDetailsRequest);
//待还原对象是Audit Detail的OldValue
AuditDetail auditDetail = auditDetailsResponse.AuditDetail;
AttributeAuditDetail attributeAuditDetail = auditDetail as AttributeAuditDetail;
//还原对象
service.Create(attributeAuditDetail.OldValue);
}

  需要注意的是,在过滤Audit记录的时候,以上面的例子来看,我们想找的是对某个Entity的delete操作,那么条件包含如下:

  1. Delete操作。在Audit Summary View中对Operation Filter的时候,可以看到有4个选项

  其实Operation是一个OptionSet:Create -> 1; Update -> 2; Delete -> 3; Access -> 4

  logicalName: operation

  2. 某个Entity。这里需要的是Entity的OTC值

  logicalName:objecttypecode

  当然,根据不同的场景,会用到不同的过滤条件,但是不管如何过滤,需要提醒一点的是,对待还原的数据多做一次确认,以免误还原,带来更多的问题。

Dynamics 365-如何利用Audit History还原被删除的数据的更多相关文章

  1. RookeyFrame 还原 软删除的数据 怎么硬删除 或者 怎么还原

     列表搜索栏上有个删除图标,可以进入回收站   如图:

  2. Dynamics 365 Online-Delete Audit History Data

    Dynamics 365 CE自带的Audit功能,虽然不会给我们的业务流程带来显著变化,但是这个功能对于我们追溯数据变化的历史,诊断定制触发的执行,以及数据还原等,都是不可或缺的关键先生.尤其是涉及 ...

  3. 利用Fiddler修改请求信息通过Web API执行Dynamics 365操作(Action)实例

    本人微信和易信公众号: 微软动态CRM专家罗勇 ,回复261或者20170724可方便获取本文,同时可以在第一间得到我发布的最新的博文信息,follow me!我的网站是 www.luoyong.me ...

  4. 利用Azure虚拟机安装Dynamics 365 Customer Engagement之一:准备工作

    我是微软Dynamics 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面 ...

  5. 利用Azure虚拟机安装Dynamics 365 Customer Engagement之十二:新增SQL Server可用性副本

    我是微软Dynamics 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面 ...

  6. 利用Azure虚拟机安装Dynamics 365 Customer Engagement之六:安装后端服务器

    我是微软Dynamics 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面 ...

  7. Dynamics 365利用Web API对视图进行查询

    我是微软Dynamics 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面 ...

  8. 利用Azure虚拟机安装Dynamics 365 Customer Engagement之十三:从可用性组中移除副本然后重新添加

    我是微软Dynamics 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面 ...

  9. 利用Azure虚拟机安装Dynamics 365 Customer Engagement之十一:SQL Server配置Always On后D365的配置更改

    我是微软Dynamics 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面 ...

随机推荐

  1. jenkins自动化工具使用教程

    自动化构建.测试.部署.代码检测越来越重要.主要有一下几点原因 1.  企业做大,项目变多,多端支持(web,h5,小程序等) 2.  微服务提倡高内聚低耦合,项目因拆分变多 3.  DevOps自动 ...

  2. 移动端web开发的注意点大总结

    对于手机网站建设,总结了如下几点注意: 1. 安卓浏览器看背景图片,有些设备会模糊. 用同等比例的图片在PC机上很清楚,但是手机上很模糊,原因是什么呢? 经过研究,是devicePixelRatio作 ...

  3. Kubernetes — 我的第一个容器化应用

    而在这篇文章中,我们就来扮演一个应用开发者的角色,使用这个 Kubernetes 集群发布第一个容器化应用. 在开始实践之前,我先给你讲解一下 Kubernetes 里面与开发者关系最密切的几个概念. ...

  4. 【二代示波器教程】第12章 示波器设计—DAC信号发生器的实现

    第12章      示波器设计—DAC信号发生器的实现 本章节为大家讲解二代示波器中信号发生器的实现.这个功能还是比较实用的,方便为二代示波器提供测试信号.实现了正弦波,方波和三角波的频率,幅度以及占 ...

  5. HashMap和HashTable简介和区别

    一.HashMap简介 HashMap是基于哈希表实现的,每一个元素是一个key-value对,其内部通过单链表解决冲突问题,容量不足(超过了阀值)时,同样会自动增长. HashMap是非线程安全的, ...

  6. [Swift]LeetCode174. 地下城游戏 | Dungeon Game

    The demons had captured the princess (P) and imprisoned her in the bottom-right corner of a dungeon. ...

  7. 安装部署jumpserver3.0

    1.安装依赖包yum -y install git readline-devel automake autoconf2.下载 jumpservergit clone https://github.co ...

  8. 使用google搜索时的10个小技巧!

    为大家分享一些google的技巧,很多工作了好几年的同学还不知道如何高效的利用这些技巧,希望同学们掌握!此为google的技巧,百度现在也基本上都实现了这些功能.   使用搜索引擎的10个搜索技巧   ...

  9. 关闭mac的SIP + 一定有用的删除mac自带ABC的方法

    如果你被这ABC输入法弄得很是不开心.那就看看吧!!!亲测一定有效. mac 关闭系统完整性保护 SIP(System Integrity Protection) 重启系统 按住 command+R ...

  10. qt实现头像上传功能

    想必大家都使用过qt的自定义头像功能吧,那么图1应该不会陌生,本片文章我就是要模拟一个这样的功能,虽然没有这么强大的效果,但是能够满足一定的需求. 图1 qq上传图片 首先在讲解功能之前,我先给出一片 ...