SharePoint 2013 中使用代码获取 search reports(Top_Queries, Abandoned_Queries,No_Result_Queries )

原创 2013年11月05日 22:23:07

本文讲述如何在SharePoint 2013 中使用代码获取 search reports(Top_Queries, Abandoned_Queries,No_Result_Queries )。

SharePoint 2013中提供多种report,供SharePoint 开发和管理人员分析和改进SharePoint  search 服务(可以在管理中心的search service 设置中找到这些报表):


但是很多情况下,普通客户也想在页面 中看到这些报表,那这种情况就需要使用代码取 search report 的数据 了。

这里贡献一段用控制台应用程序读 report 数据的代码 ,注意如果要在 web part里面使用这些代码必须提权 (SPSecurity.RunWithElevatedPrivileges):

1. 首先在控制台应用程序中添加Dll引用 

  •  Microsoft.Office.Server.dll
  • Microsoft.Office.Server.Search.dll
  • Microsoft.Office.Server.Search.Applications.dll
  • Microsoft.SharePoint.dll

2. 将控制台应用程序的Target platform 改为X64

3. Program.cs代码如下:

using Microsoft.Office.Server.Search.Administration;
using Microsoft.Office.Server.Search.Analytics;
using Microsoft.Office.Server.Search.Query;
using Microsoft.SharePoint;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            if (args.Length != 2)
            {
                Console.WriteLine("Please use : GetTopSearchQueryText.exe siteUrl topNumber");
            }
            else
            {
                try
                {
                    using (SPSite oSPsite = new SPSite(args[0]))
                    {
                        Microsoft.SharePoint.SPServiceContext context = SPServiceContext.GetContext(oSPsite);
                        SearchServiceApplicationProxy searchProxy = context.GetDefaultProxy(typeof(SearchServiceApplicationProxy)) as SearchServiceApplicationProxy;
                        SearchServiceApplicationInfo ssai = searchProxy.GetSearchServiceApplicationInfo();
                        SearchServiceApplication searchApp = SearchService.Service.SearchServiceApplications.First<SearchServiceApplication>();                       
                        for (int i = 0; i < 100; i++)
                        {
                            var reports = searchApp.GetSearchReport(i, Guid.Empty, oSPsite.ID, DateTime.Now.AddMonths(-2), false, uint.Parse(args[1]));
                            // GetSearchReport 的第一参数 report type 含义,微软的文档没有说,就让传int32,经过笔者循环验证的结论
                            // 1 : Top_Queries
                            // 2: Abandoned_Queries
                            // 3: No_Result_Queries

                            Console.WriteLine("reports.Count:" + reports.Count);
                            foreach (QueryReportData report in reports)
                            {
                                Console.WriteLine("Query:" + report.Query + ", count:" + report.Count + ", Scope:" + report.Scope);
                            }
                        }                        
                    }
                }
                catch (Exception ex)
                {
                    Console.WriteLine("error:"  + ex.Message);
                    Console.WriteLine("StackTrace:" + ex.StackTrace);
                }

                Console.WriteLine("Press any key to exit");
                Console.ReadKey();
            }
        }
    }
}





  


OAF实现客户化查询

在OAF中,存在标准的查询面板,但是标准的查询只能实现基础、简单的查询,所以在真正的项目当中,一般情况下都是使用自己开发的客户化查询,开发客户化查询的一般步骤如下: 1. 建立页面PG,修改Regio...
  • wang_zhou_jian
  • wang_zhou_jian
  • 2010年08月03日 14:01
  • 3811

Metasploit Framework

### $Id: eiqnetworks_esa.rb 4529 2007-03-12 01:08:18Z hdm $##### This file is part of the Metasploit...
  • kzh4435
  • kzh4435
  • 2007年10月24日 14:14
  • 273

Jquery(Ajax) 调用 SharePoint 2013 Search Rest API 并使用Josn反回结果并简单显示

Jquery(Ajax) 调用 SharePoint 2013 Search Rest API 并使用Josn反回结果并简单显示:   SharePoint 2010 中使用的 searc...
  • farawayplace613
  • farawayplace613
  • 2013年01月05日 21:51
  • 4629

SharePoint 2013 SharePoint designer 2013 workflow开发综合实例

本文讲述一个SharePoint 2013 SharePoint designer 2013 workflow开发综合实例.
  • farawayplace613
  • farawayplace613
  • 2013年10月11日 19:11
  • 4601

菜单实现

概览页面.i {  font-size: 9pt}var Flag=true;var MessageVar = "                    正在调入网页,请稍等......       ...
  • findme123
  • findme123
  • 2005年09月28日 10:16
  • 637

Grails导出csv格式的文件

grails让csv报表的导出变得简单,还不快来看看。
  • chenwill3
  • chenwill3
  • 2014年05月25日 14:50
  • 1067

sharepoint 2013 中修改母版页简单介绍

1.打开网站操作:设计管理器中创建html母版页,系统会自动生成.master的母版页 2.打开spd编辑签出新建的html的母版页,在中上面加上style="overflow:auto;",增加滚动...
  • dyp330
  • dyp330
  • 2013年07月05日 11:10
  • 4582

SharePoint 2013 开发——获取用户配置文件属性内容(User Profile)

SharePoint 2013 开发——获取用户配置文件属性内容(User Profile)
  • FoxDave
  • FoxDave
  • 2015年07月21日 09:11
  • 2622

青葱岁月程序收藏

REPORT  ZZBPP_SCTZ_MJ. TABLES: ZZTPP_ZSTZ_HEAD,         ZZTPP_ZSTZ_BODY1,         ZZTPP_ZSTZ_...
  • zhongguomao
  • zhongguomao
  • 2016年10月29日 08:58
  • 602

dfsadmin -report结果分析

最近在搭建hadoop集群实验中,启动集群时常报错:jobtracker.info could only be replicated to 0 nodes, instead of 1 查了好多资...
  • huoyunshen88
  • huoyunshen88
  • 2013年06月13日 21:45
  • 3855
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:SharePoint 2013 中使用代码获取 search reports(Top_Queries, Abandoned_Queries,No_Result_Queries )
举报原因:
原因补充:

(最多只允许输入30个字)