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. MongoDB 复制机制

    一.复制原理 MongoDB的复制功能是使用操作日志oplog实现的,oplog包含主节点(Master)的每一次写操作,oplog是local本地数据库中的一个数据集合,其它非主节点(Seconda ...

  2. mantisbt的配置与安装

    下载并安装wampserver; 安装时,提示SMTP服务器时,应正确填写邮箱的SMTP的服务器地址: 安装完成后,登录phpMyAdmin; 给原有的root用户创建密码,所有root用户: 创建一 ...

  3. 【RL-TCPnet网络教程】第9章 RL-TCPnet网络协议栈移植(uCOS-III)

    第9章        RL-TCPnet网络协议栈移植(uCOS-III) 本章教程为大家讲解RL-TCPnet网络协议栈的uCOS-III操作系统移植方式,学习了第6章讲解的底层驱动接口函数之后,移 ...

  4. 字符串匹配(一)----Rabin-Karp算法

    题目:假如要判断字符串A"ABA"是不是字符串B"ABABABA"的子串. 解法一:暴力破解法, 直接枚举所有的长度为3的子串,然后依次与A比较,这样就能得出匹 ...

  5. MYSQL手册

    原文出处:http://www.cnblogs.com/gaofei-1/p/7152875.html MySQL配置文件 MySQL软件使用的配置文件名为my.ini,在安装目录下. MySQL常用 ...

  6. [Swift]LeetCode492. 构造矩形 | Construct the Rectangle

    For a web developer, it is very important to know how to design a web page's size. So, given a speci ...

  7. [Swift]LeetCode923.三数之和的多种可能 | 3Sum With Multiplicity

    Given an integer array A, and an integer target, return the number of tuples i, j, k  such that i &l ...

  8. [Swift]LeetCode935. 骑士拨号器 | Knight Dialer

    A chess knight can move as indicated in the chess diagram below:  .            This time, we place o ...

  9. [Swift]LeetCode957. N天后的牢房 | Prison Cells After N Days

    There are 8 prison cells in a row, and each cell is either occupied or vacant. Each day, whether the ...

  10. grep的正则表达式结合的几个典型应用

    一 几个特殊的字符: ^ :只匹配行首  如^a 匹配以a开头的行abc,a2e,a12,aaa,...... example: grep "^a" //列出所有以a开头的行 $ ...