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();
            }
        }
    }
}





  


Writing CAML Queries For Retrieving List Items from a SharePoint List1

IntroductionThe Collaborative Application Markup Language (better known as CAML) is an XML-based que...

使用CSS3 Media Queries实现响应式设计

文章来源:http://bbs.html5cn.org/forum.php?mod=viewthread&tid=11516&extra=   现在屏幕分辨率的范围很大,从 320px ...

CSS之不使用Media Queries的自适应CSS

css

定义css设备类型-Media Queries图表简介及使用方法

移动时代是任何网页设计师和开发者不可忽略的一个时代,现在我设计的页面有时会在电脑大屏幕上或者移动小屏幕上显示。如何让同一个网站同时适应完全不同尺寸的屏幕,CSS3完美地解决了这些问题。在CSS2.1版...
  • judyge
  • judyge
  • 2016年07月08日 21:42
  • 519

CSS3 Media Queries 详细介绍与使用方法,Responsive Web Design 必备技术

上一篇我们介绍了Responsive Web Design之后,这次要来详细介绍CSS3 Media Queries了。 在上一篇中,我們提到Responsive Web Desig n 的實...

如何在网页中使用媒体查询 media queries

响应试设计目前早已渗透到web前端的方方面面,说到响应式设计我们就会用到媒体查询(media queries),它可以帮助你根据浏览器尺寸对网页中的元素信息相应的布局调整,当然你还可以借助css3的一...

使用CSS3 Media Queries实现网页自适应

当今银屏分辨率从 320px (iPhone)到 2560px (大屏显示器)或者更大。人们也不再仅仅用台式机来浏览网页,现在有手机,平板电脑等等。所以传统的固定宽度设计形式将不再是个最佳选择,网页设...

Nearest Neighbor Queries

  • 2012年10月10日 21:47
  • 205KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:SharePoint 2013 中使用代码获取 search reports(Top_Queries, Abandoned_Queries,No_Result_Queries )
举报原因:
原因补充:

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