SharePoint log分析——一句SQL语句找出无效的Event Receiver

本文主要是介绍SharePoint log分析——一句SQL语句找出无效的Event Receiver,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在SharePoint的log中有时候会出现这样的错误信息:

“Couldnot load file or assembly 'AssemblyName,Version=..., Culture=neutral, PublicKeyToken=... ...' or one ofits dependencies. The system cannot find the file specified.”

从这里可以判断出某个代码集找不到了,如果在Event Viewer中可以看到Event ID为6644的错误,例如:

Event Type: Error
Event Source: 
Event Category: General 
Event ID: 6644
Date:  1/10/2012
Time:  10:26:44 AM
User:  N/A
Computer: 
Description:

这时就可以断定SharePoint系统中出现了无效的Event Receiver了(即Orphaned Event Receiver)。

无效的Event Receiver就是其所引用的代码集丢失了的event receiver,大家知道在定义Event Receiver的时候,需要指定所引用的代码集,如果执行event receiver的时候,找不到代码集,就会出现这样的错误信息。

出现问题的可能原因是:一般在feature被激活的时候通过代码创建event receivers,在deactivate feature的时候,删除event receivers,如果没有deactivate feature,直接在管理中心retract或者delete solution,就可能造成这样的错误。

一般解决问题的方法就是重新部署solution,或者彻底删除无效的event receivers。重新部署就没什么可以说的了,如果是想删除这些event receivers,首先需要找到都是哪些list中的event receivers是无效的,这里有一个方法,可以在内容数据库中执行以下查询语句,一次查找出来所有的跟某个代码集有关的无效event receivers:

select webs.Title, Alllists.tp_Title from EventReceivers with (nolock) 
inner join Webs on EventReceivers.WebId = webs.Id
inner join AllLists on EventReceivers.HostId = Alllists.tp_ID
where Assembly like '%代码集的名字%'

其中表“EventReceivers”中保存了所有的event receiver的信息,其中的“Assembly”列中保存的是其所引用的代码集的名字。因为“EventReceivers”表中只保存了站点和列表的id,所以要连接“Webs”和“AllLists”表来获得站点和列表的名字。

这样就可以找到所有的与某个代码集相关的无效event receivers了,然后可以使用这个工具,将它们删除干净:EventReceiver Manager


也可以使用SharePoint Management Shell命令找出无效的event receivers,并将它们删除,参见:点击打开链接

这篇关于SharePoint log分析——一句SQL语句找出无效的Event Receiver的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/473373

相关文章

MySQL 分区与分库分表策略应用小结

《MySQL分区与分库分表策略应用小结》在大数据量、复杂查询和高并发的应用场景下,单一数据库往往难以满足性能和扩展性的要求,本文将详细介绍这两种策略的基本概念、实现方法及优缺点,并通过实际案例展示如... 目录mysql 分区与分库分表策略1. 数据库水平拆分的背景2. MySQL 分区策略2.1 分区概念

MySQL高级查询之JOIN、子查询、窗口函数实际案例

《MySQL高级查询之JOIN、子查询、窗口函数实际案例》:本文主要介绍MySQL高级查询之JOIN、子查询、窗口函数实际案例的相关资料,JOIN用于多表关联查询,子查询用于数据筛选和过滤,窗口函... 目录前言1. JOIN(连接查询)1.1 内连接(INNER JOIN)1.2 左连接(LEFT JOI

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

MySQL中动态生成SQL语句去掉所有字段的空格的操作方法

《MySQL中动态生成SQL语句去掉所有字段的空格的操作方法》在数据库管理过程中,我们常常会遇到需要对表中字段进行清洗和整理的情况,本文将详细介绍如何在MySQL中动态生成SQL语句来去掉所有字段的空... 目录在mysql中动态生成SQL语句去掉所有字段的空格准备工作原理分析动态生成SQL语句在MySQL

MySQL中FIND_IN_SET函数与INSTR函数用法解析

《MySQL中FIND_IN_SET函数与INSTR函数用法解析》:本文主要介绍MySQL中FIND_IN_SET函数与INSTR函数用法解析,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一... 目录一、功能定义与语法1、FIND_IN_SET函数2、INSTR函数二、本质区别对比三、实际场景案例分

Python 迭代器和生成器概念及场景分析

《Python迭代器和生成器概念及场景分析》yield是Python中实现惰性计算和协程的核心工具,结合send()、throw()、close()等方法,能够构建高效、灵活的数据流和控制流模型,这... 目录迭代器的介绍自定义迭代器省略的迭代器生产器的介绍yield的普通用法yield的高级用法yidle

MySQL中的交叉连接、自然连接和内连接查询详解

《MySQL中的交叉连接、自然连接和内连接查询详解》:本文主要介绍MySQL中的交叉连接、自然连接和内连接查询,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、引入二、交php叉连接(cross join)三、自然连接(naturalandroid join)四

Mysql如何将数据按照年月分组的统计

《Mysql如何将数据按照年月分组的统计》:本文主要介绍Mysql如何将数据按照年月分组的统计方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql将数据按照年月分组的统计要的效果方案总结Mysql将数据按照年月分组的统计要的效果方案① 使用 DA

Mysql表如何按照日期字段的年月分区

《Mysql表如何按照日期字段的年月分区》:本文主要介绍Mysql表如何按照日期字段的年月分区的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、创键表时直接设置分区二、已有表分区1、分区的前置条件2、分区操作三、验证四、注意总结一、创键表时直接设置分区

Go 语言中的select语句详解及工作原理

《Go语言中的select语句详解及工作原理》在Go语言中,select语句是用于处理多个通道(channel)操作的一种控制结构,它类似于switch语句,本文给大家介绍Go语言中的select语... 目录Go 语言中的 select 是做什么的基本功能语法工作原理示例示例 1:监听多个通道示例 2:带