菜单

报表服务中的SharePoint集成模式配置,Services生成报表

2020年4月9日 - 4166am金沙下载
报表服务中的SharePoint集成模式配置,Services生成报表

核心提示:灵活的报表功能是大多数业务应用程序的一个要求,这些报表功能在集成到
Web 应用程序中之后用途更加广泛

本文转自:

 

灵活的报表功能是大多数业务应用程序的一个要求,这些报表功能在集成到 Web
应用程序中之后用途更加广泛。利用 SQL Serverreg; 2000 Reporting Services
的最新版本,您可以轻松地具有来自各种数据源的报表生成功能。在本文中,我将介绍使用
Visual Studioreg; 和 Reporting Services
来编写报表,并演示如何将报表集成到 Web 应用程序中。

 

前言

在sql
server2012报表配置管理器上没有“sharepint集成”模式选择项(采用新建),如下图:

图片 1

怎么回事情呢?后来通过查询资料才知道,如下:

重要提示

从 SQL Server 2012 版本开始,Reporting Services 配置管理员不设计用来管理 SharePoint 模式报表服务器。 SharePoing 模式通过使用 SharePoing 管理中心和 PowerShell 脚本进行管理和配置。 有关为 SharePoint 集成模式安装和配置 Reporting Services 的信息,请参阅 SQL Server 联机丛书中的安装 Reporting Services SharePoint 模式作为单服务器场

重要提示

配置和管理 Reporting Services SharePoint 模式不再需要或支持 Reporting Services 配置管理器。 使用 SharePoint 管理中心在 SharePoint 模式中配置报表服务器。 有关详细信息,请参阅管理 Reporting Services 服务应用程序

Reporting Services 是基于服务器的报表生成平台,该平台构建在 .NET
Framework 上并与 SQL Server 2000
集成在一起,因此您可以使用一个扩展的基于 Web 服务的 API
将丰富的报表生成功能集成到应用程序中。尽管报表服务器使用 SQL Server
作为报表的储存库,但利用 OLE DB、ODBC 或 ADO.NET
提供程序的任何数据源都可以用来为报表提供数据,这就使得 Reporting
Services 成为在各种企业环境中生成报表的极佳工具。

若要查看部署到报表服务器的报表或在本地文件系统上存在的报表,您可以在 Web
应用程序中使用 WebForms ReportViewer 控件来呈现它们。

安装Sql Server2012数据库

· 本主题不涉及安装 SharePoint 2010 产品。 有关详细信息,请参阅在
SharePoint 场中使用 SQL Server BI
功能的指南。

· 这些过程适用于配置 SQL Server 2012 报表服务器,而不能用于未使用
SharePoint 共享服务体系结构的报表服务器早期版本。 例如,SQL Server 2008
Reporting Services 报表服务器和 SQL Server 2008 R2 Reporting Services
报表服务器。

· 验证是否已在 Windows 服务器管理器中启动“SharePoint 2010
管理”服务。

图片 2

Reporting Services 是作为 SQL Server 2000
的一部分而授权的,因此如果您有已授权的 SQL Server
的副本,则可以在同一服务器上运行 Reporting Services
而无需支付额外的许可证费用。如果您决定在独立的、尚未经 SQL Server
授权的计算机(例如,Web 服务器)上运行 Reporting
Services,您将需要购买额外的 SQL Server 许可证。

 

单服务器配置的数据库注意事项

· Reporting Services 和 SharePoint 产品及技术均使用 SQL Server
关系数据库来存储应用程序数据。

· SQL Server 2012 Reporting Services (SSRS) 需要兼容的 SQL 引擎的 SQL
Server 评估版实例。 有关硬件和软件要求的详细信息,请参阅安装 SQL Server
2012
的硬件和软件要求。

· 如果已安装了数据库实例,则 SharePoint 产品可以使用现有的数据库实例。
如果未安装数据库引擎实例,则 SharePoint 产品安装程序将安装 SQL Server
Express Edition 以用于 SharePoint 应用程序数据库。

· 报表服务器实例不能将 SQL Server Express Edition 用于其数据库。
但是,由 SharePoint 产品安装的 SQL Server Express Edition
实例可以与您也可能安装的其他数据库引擎版本并存。

要开始使用 Reporting Services,您可以下载位于 SQL Server 2000 Reporting
Services 的 120
天试用版软件,它还包括有关如何获得该产品的安装媒体的说明。在安装该产品时,请确保选中包括示例报表的选项,因为我要将这些报表集成到本文的
Web 应用程序中。

 

在 SharePoint 模式下安装 Reporting Services 报表服务器
  1. 运行 SQL Server 安装向导。
  2. 在向导的左侧单击“安装”,然后单击“全新 SQL Server
    独立安装或向现有安装添加功能”
  3. “安装程序支持规则”页上单击“确定”,假定所有规则均已通过验证。
  4. “安装程序支持文件”页中,单击“安装”
  5. 在支持文件已完成安装并且支持规则显示“已通过”状态后,单击“下一步”
    查看任何警告或妨碍安装的问题。
  6. “产品密钥”页中,键入密钥或接受 Enterprise Evaluation Edition
    的默认密钥。

单击“下一步”

  1. 阅读并接受许可条款。
    对于您单击以同意发送功能使用情况数据来帮助改进产品功能和支持,Microsoft
    深表感谢。

单击“下一步”

  1. “安装角色”页上选择“SQL Server 功能安装”

单击“下一步”

图片 3

  1. “功能选择”页中,选择以下选项:

· Reporting Services – SharePoint

· 用于 SharePoint 2010 产品的 Reporting Services
外接程序
图片 4
用于安装外接程序的安装向导选项是 SQL Server 2012 版中的新增功能。

· 如果您尚未安装 SQL Server Database Engine
实例,则您还可以选择“数据库引擎服务”“管理工具
完整”以提供一个完整环境。

单击“下一步”

  1. “安装规则”页上单击“下一步”
    查看任何警告或妨碍安装的问题。
  2. 如果您已选择“数据库引擎服务”,请在“实例配置”页上接受
    MSSQLSERVER 的默认实例,然后单击“下一步”。 与以前的
    Reporting Services 体系结构不同,Reporting Services
    共享服务体系结构不基于实例。
  3. 阅读“磁盘空间要求”页,然后单击“下一步”
  4. “服务器配置”页上键入相应的凭据。 如果您要使用 Reporting
    Services 数据警报或订阅功能,则需要将 SQL Server
    代理的“启动类型”更改为“自动”

单击“下一步”

  1. 如果您选择了“数据库引擎服务”,您将看到“数据库引擎配置”页。请将相应的帐户添加到
    SQL 管理员列表,然后单击“下一步”
  2. “Reporting Services
    配置”页上,您将看到“仅安装”选项处于选中状态。
    此选项将安装报表服务器文件,它将不会为 Reporting Services 配置
    SharePoint 环境。SQL Server
    安装完成后,您需要按照本主题的其他章节的内容配置 SharePoint 环境。
    这包括安装 Reporting Services 共享服务和创建 Reporting Services
    服务应用程序。

  1. 请通过在“错误报告”页上单击用于发送错误报告的复选框,来帮助
    Microsoft 改进 SQL Server 功能和服务。

单击“下一步”

  1. 查看任何警告,然后在“安装配置规则”页上单击“下一步”
  2. “准备安装”页上,查看安装摘要,然后单击“下一步”
    该摘要将包含一个 Reporting Services 节点,该节点将包含
    SharePointFilesOnlyMode 的安装模式值以及帐户信息。

 

Reporting Services 概述

 

配置SharePoint集成模式下的Report Services

 

Reporting Services 报表设计使用新的 Visual Studio .NET 2003
报表设计器,在安装有 Visual Studio 的同一计算机上安装了 Reporting
Services 后,该设计器就可以使用。设计器以新的基于 XML 报表定义语言 (RDL)
输出报表布局和数据访问的说明,而 RDL
文件会发布到报表服务器。如果您希望为用户提供创作功能,也可以使用第三方的报表设计器。

 

Powershell脚本配置Reporting Services

在执行 SQL Server 安装向导的过程中已安装了必需的文件,但需要将服务注册到
SharePoint 场中。 SQL Server 2012 版本引入了对 SharePoint 模式下的
Reporting Services 的 PowerShell 支持。 以下步骤将指导您完成打开
SharePoint Management Shell 并运行 cmdlet 的过程:

  1. 单击“开始”按钮
  2. 单击“Microsoft SharePoint 2010 产品”组。如下图:

图片 5

  1. 右键单击“SharePoint 2010 Management
    Shell”
    ,然后单击“以管理员身份运行”
  2. 运行以下 PowerShell 命令以安装 SharePoint 服务。 命令成功完成后会在
    Management Shell 中生成一个新行。 当命令成功完成时,不会向
    Management Shell 返回任何消息:

Install-SPRSService

  1. 运行以下 PowerShell 命令以安装服务代理:

Install-SPRSServiceProxy

  1. 运行以下 PowerShell 命令以启动服务,或者查看下面的注释以了解有关从
    SharePoint 管理中心启动服务的说明:

get-spserviceinstance -all |where {$_.TypeName -like “SQL Server
Reporting*”} | Start-SPServiceInstance

如下图:

图片 6

您也可以从 SharePoint 管理中心(而不是通过运行第三个 PowerShell
命令)来启动服务。 以下步骤对于验证服务是否正在运行很有用。

  1. 在 SharePoint
    管理中心的“系统设置”组中,单击“管理服务器上的服务”

图片 7

  1. 找到“SQL Server Reporting Services
    服务”,然后在“操作”列中单击“启动”

图片 8

  1. Reporting Services 服务的状态将从“已停止”更改为“已启动”
    如果 Reporting Services 服务不在列表中,请验证是否已使用 PowerShell
    安装了该服务。

注意

如果 Reporting Services 服务停留在“正在启动”状态,并且未更改为“已启动”,请验证是否已在 Windows 服务器管理器中启动“SharePoint 2010 管理”服务。

管理员可以使用基于 Web
的报表管理器来管理已发布的报表,并且可以执行一些任务,例如,保证某些用户组报表的安全或更改已部署报表的数据源连接字符串。用户也可以使用报表管理器来浏览和查看报表;但是很多公司倾向于使用
URL 请求或 Reporting Services Web
服务,将报表查看直接集成到它们现有的内部 Web 站点或应用程序中。

 

 

图 1 Reporting Services 体系结构

 

创建 Reporting Services 服务应用程序

本节提供您在查看现有服务应用程序的情况下,用于创建新的服务应用程序的步骤和属性说明。

  1. 在 SharePoint
    管理中心的“应用程序管理”组中,单击“管理服务应用程序”

图片 9

  1. 在 SharePoint 功能区中,单击“新建”按钮。
  2. 在“新建”菜单中,单击“SQL Server Reporting Services
    服务应用程序”

图片 10

注意

如果 Reporting Services 选项没有出现在列表中,则表明 Reporting Services 共享服务尚未安装。 查看上一节,了解如何使用 PowerShell cmdlt 安装 Reporting Services 服务。

  1. “创建 SQL Server Reporting Services
    服务应用程序”页中,输入应用程序的名称。 如果您要创建多个
    Reporting Services
    服务应用程序,则一个描述性名称或命名约定将帮助您组织长期的管理操作。
  2. “应用程序池”部分中,为该应用程序创建一个新应用程序池(推荐)。
    使用与服务应用程序相同的名称作为新应用程序池的名称,可能会使您正在进行的管理更加容易。

为该应用程序池选择或创建一个托管帐户。 请确保指定一个域用户帐户。
通过域用户帐户,可以使用 SharePoint
的托管帐户功能,从而使您可以在一个位置中更新密码和帐户信息。
如果您计划扩展部署以便包括将在同一标识下运行的附加服务实例,则域帐户也是必需的。

图片 11

  1. “数据库服务器”中,您可以使用当前服务器或选择其他 SQL Server。
  2. “数据库名称”中,默认值是
    ReportingService_<guid>,该名称是唯一的数据库名称。
    如果要键入新值,您必须键入唯一的值,因为我们建议对每个服务应用程序都使用唯一的数据库。

图片 12

  1. “数据库身份验证”中,默认值是“Windows 身份验证”。
    如果您选择“SQL 身份验证”,请参考 SharePoint
    管理员指南以便了解有关如何在 SharePoint
    部署中使用此身份验证类型的最佳实践。

图片 13

  1. “Web 应用程序关联”部分中,选择要设置为供当前 Reporting
    Services 服务应用程序访问的 Web 应用程序。 可以将一个 Reporting
    Services 服务应用程序与一个 Web 应用程序相关联。 如果所有当前 Web
    应用程序均已与一个 Reporting Services
    服务应用程序相关联,则将显示警告消息。

图片 14

  1. 单击“确定”

可以将报表参数化,这样用户可以在查看报表时从选择列表中进行挑选;它们还可以导出为多种格式,例如,Microsoftreg;Excel、PDF

XML。尽管实时报表提供最新的数据,也可以将报表缓存一段时间以提高性能并减少数据源上的负载。对于商务智能应用程序,报表可以访问
Analysis Services OLAP 多维数据集,而且 Reporting Services
甚至可以导入现有的 Microsoft Access
报表,尽管由于这两种技术间存在差异,它并不能支持所有的 Access 功能。有关
Reporting Services 体系结构的详细情况,请参见图 1。

将 ReportViewer 控件添加到 Web 应用程序

  1. 使用
    Microsoft Visual C# 或 Microsoft Visual Basic 创建一个新的
    Microsoft ASP.NET 网站。


    或 –

    打开一个现有的
    ASP.NET 网站并添加一个新的 Web 窗体。

  2. 在“工具箱”中找到 ReportViewer 控件。 如果“工具箱”不可见,则可以通过从“视图”菜单中选择“工具箱”来进行访问。


  3. ReportViewer 控件拖到 Web 窗体的设计图面上。

    名为
    reportViewer1 的 ReportViewer 控件便添加到该窗体中。

将控件添加到该窗体之后,“ReportViewer
任务”智能标记将出现,提示您选择某一报表。 如果您要查看的报表已部署到报表服务器上,则从“选择报表”下拉列表中选择<服务器报表>选项。 选择<服务器报表>选项后,将出现两个附加的属性:“报表服务器 URL”和“报表路径”。 “报表服务器 URL”是指向相应报表服务器的地址,“报表路径”是指向要呈现的报表的完整路径。
如果您想要以本地模式查看报表,则选择“设计新报表”选项以启动报表设计器或选择已是现有项目的一部分的报表。

在远程处理模式下查看报表)


下面的示例演示如何呈现已部署到某一报表服务器的报表。
此示例使用     AdventureWorks2012  
示例报表项目随附的 Sales Order Detail 报表。

该示例使用集成的
Windows 身份验证,因此您首先必须启用模拟。 为此,将以下行插入
web.config 文件:

 

复制window.epx.codeSnippet.copyCode(‘CodeSnippetContainerCode_0ff6de4d-61a7-4a1b-a1a8-dc6e9b1ce19d’);)

<!-- Web.config file. -->
<identity impersonate="true"/>
注意

默认情况下,模拟处于禁用状态。

C#

VB

复制window.epx.codeSnippet.copyCode(‘CodeSnippetContainerCode_2aa292be-4209-49db-8bcb-ecc34256c22b’);)

protected void Page_Init(object sender, EventArgs e)
{
    if (!Page.IsPostBack)
    {
        // Set the processing mode for the ReportViewer to Remote
        reportViewer.ProcessingMode = ProcessingMode.Remote;

        ServerReport serverReport = reportViewer.ServerReport;

        // Set the report server URL and report path
        serverReport.ReportServerUrl =
            new Uri("http://<Server Name>/reportserver");
        serverReport.ReportPath =
            "/AdventureWorks Sample Reports/Sales Order Detail";

        // Create the sales order number report parameter
        ReportParameter salesOrderNumber = new ReportParameter();
        salesOrderNumber.Name = "SalesOrderNumber";
        salesOrderNumber.Values.Add("SO43661");

        // Set the report parameters for the report
        reportViewer.ServerReport.SetParameters(
            new ReportParameter[] { salesOrderNumber });
    }
}

在本地处理模式下查看报表)


下面的示例演示如何呈现作为
Windows 应用程序的一部分并且尚未部署到报表服务器的报表。

设计第一个报表

 

尽管我介绍的重点在于将报表集成到应用程序中而不是创作报表,但熟悉
Reporting Services
的最好办法就是立即着手创建一个新的报表项目。为此,请打开 Visual Studio
并使用 Report Project Wizard 创建一个新的项目,该向导位于 Business
Intelligence Projects
部分。为您的项目指定一个名称,单击“OK”,然后将显示报表向导对话框。在您选择数据源的这一步骤中,单击“Edit”按钮,以便指定连接到您数据库服务器上的
AdventureWorks2000,单击“OK”,然后选中使其成为共享数据源的选项。

 

单击“Next”进入到“Design the Query”步骤,指定简单的 SQL
语句(例如,“SELECT * FROM Product”),然后单击“Next”。Reporting Services
支持显示一组固定列的标准表格式 (Tabular)
报表,也支持使用带有动态列的交叉表样式视图的矩阵式 (Matrix)
报表,因此为该报表选择 Tabular,然后单击“Next”。

 

将某些列(例如,ProductID 和 Name)拖到 Details
部分并单击“Next”。选择默认的 Bold
样式,单击“Next”,然后指定您的报表服务器的虚拟目录的
URL,例如,。现在,单击“Next”。最后一步,您可以为您的第一个报表指定名称,例如,Products
Report;然后单击“Finish”。

 

该向导将会创建该项目,同时还创建一个可以由多个报表共享
AdventureWorks2000 数据源,以及一个在设计器中打开的有关 Products
数据的报表(请参见图 2)。默认情况下,显示使您可以修改报表设计的 Layout
选项卡。

 

图 2 Visual Studio 报表设计器

 

Data
选项卡用于指定报表的查询,包括设置参数以便在执行报表时提示用户提供值。单击“Preview”选项卡来测试报表显示给用户的方式。

将 Sales Order Detail 报表添加到网站

  1. 打开该报表将添加到的网站。

  2. 在“网站”菜单中,选择“添加现有项”。

  3. 浏览到安装了
    AdventureWorks 报表示例项目的位置。

    默认位置是
    C:\Program Files\Microsoft SQL Server\100\Samples\Reporting
    Services\Report Samples\AdventureWorks Sample Reports。

  4. 选择
    Sales Order Detail.rdl 文件并单击“添加”按钮。

    Sales
    Order Detail.rdl 文件现在应是该项目的一部分。

  5. 在解决方案资源管理器中右键单击
    Sales Order Detail.rdl 文件,然后选择“重命名”。 将该报表重命名为
    Sales Order Detail.rdlc,然后按 Enter。

    如果解决方案资源管理器不可见,则可以通过从“视图”菜单中选择“解决方案资源管理器”来将其打开。

现在,您可以将附加的报表添加到该项目,或者通过添加附加列、将数据分组、添加汇总、甚至是添加能够显示来自其他查询的数据的附加表来修改
Products 报表。与很多报表设计器不同,Reporting Services
使用带外设计,这使得它可以轻松地创建将各种源的数据集中在同一个位置的报表。
您刚刚创建的报表项目由当前驻留在您的开发计算机上的一组文件组成。为了将这些报表发布给用户,您需要将该项目部署到报表服务器。

 

以下代码示例将为销售订单数据创建一个数据集,然后以本地模式呈现
Sales Order Detail 报表。

C#

VB

复制window.epx.codeSnippet.copyCode(‘CodeSnippetContainerCode_5b2d9d9f-d223-4308-a60b-eff4256eeade’);)

protected void Page_Init(object sender, EventArgs e)
{
    if (!Page.IsPostBack)
    {
        // Set the processing mode for the ReportViewer to Local
        reportViewer.ProcessingMode = ProcessingMode.Local;

        LocalReport localReport = reportViewer.LocalReport;

        localReport.ReportPath = "Sales Order Detail.rdlc";

        DataSet dataset = new DataSet("Sales Order Detail");

        string salesOrderNumber = "SO43661";

        GetSalesOrderData(salesOrderNumber, ref dataset);

        ReportDataSource dsSalesOrder = new ReportDataSource();
        dsSalesOrder.Name = "SalesOrder";
        dsSalesOrder.Value = dataset.Tables["SalesOrder"];

        localReport.DataSources.Add(dsSalesOrder);

        GetSalesOrderDetailData(salesOrderNumber, ref dataset);

        ReportDataSource dsSalesOrderDetail = new ReportDataSource();
        dsSalesOrderDetail.Name = "SalesOrderDetail";
        dsSalesOrderDetail.Value = dataset.Tables["SalesOrderDetail"];

        localReport.DataSources.Add(dsSalesOrderDetail);

        // Create the sales order number report parameter
        ReportParameter rpSalesOrderNumber = new ReportParameter();
        rpSalesOrderNumber.Name = "SalesOrderNumber";
        rpSalesOrderNumber.Values.Add("SO43661");

        // Set the report parameters for the report
        localReport.SetParameters(
            new ReportParameter[] { rpSalesOrderNumber });
    }
}

private void GetSalesOrderData(string salesOrderNumber,
                           ref DataSet dsSalesOrder)
{
    string sqlSalesOrder =
        "SELECT SOH.SalesOrderNumber, S.Name AS Store, " +
        "       SOH.OrderDate, C.FirstName AS SalesFirstName, " +
        "       C.LastName AS SalesLastName, E.Title AS " +
        "       SalesTitle, SOH.PurchaseOrderNumber, " +
        "       SM.Name AS ShipMethod, BA.AddressLine1 " +
        "       AS BillAddress1, BA.AddressLine2 AS " +
        "       BillAddress2, BA.City AS BillCity, " +
        "       BA.PostalCode AS BillPostalCode, BSP.Name " +
        "       AS BillStateProvince, BCR.Name AS " +
        "       BillCountryRegion, SA.AddressLine1 AS " +
        "       ShipAddress1, SA.AddressLine2 AS " +
        "       ShipAddress2, SA.City AS ShipCity, " +
        "       SA.PostalCode AS ShipPostalCode, SSP.Name " +
        "       AS ShipStateProvince, SCR.Name AS " +
        "       ShipCountryRegion, CC.Phone AS CustPhone, " +
        "       CC.FirstName AS CustFirstName, CC.LastName " +
        "       AS CustLastName " +
        "FROM   Person.Address SA INNER JOIN " +
        "       Person.StateProvince SSP ON " +
        "       SA.StateProvinceID = SSP.StateProvinceID " +
        "       INNER JOIN Person.CountryRegion SCR ON " +
        "       SSP.CountryRegionCode = SCR.CountryRegionCode " +
        "       RIGHT OUTER JOIN Sales.SalesOrderHeader SOH " +
        "       LEFT OUTER JOIN  Person.Contact CC ON " +
        "       SOH.ContactID = CC.ContactID LEFT OUTER JOIN" +
        "       Person.Address BA INNER JOIN " +
        "       Person.StateProvince BSP ON " +
        "       BA.StateProvinceID = BSP.StateProvinceID " +
        "       INNER JOIN Person.CountryRegion BCR ON " +
        "       BSP.CountryRegionCode = " +
        "       BCR.CountryRegionCode ON SOH.BillToAddressID " +
        "       = BA.AddressID ON  SA.AddressID = " +
        "       SOH.ShipToAddressID LEFT OUTER JOIN " +
        "       Person.Contact C RIGHT OUTER JOIN " +
        "       HumanResources.Employee E ON C.ContactID = " +
        "       E.ContactID ON SOH.SalesPersonID = " +
        "       E.EmployeeID LEFT OUTER JOIN " +
        "       Purchasing.ShipMethod SM ON SOH.ShipMethodID " +
        "       = SM.ShipMethodID LEFT OUTER JOIN Sales.Store" +
        "        S ON SOH.CustomerID = S.CustomerID " +
        "WHERE  (SOH.SalesOrderNumber = @SalesOrderNumber)";

    SqlConnection connection = new
        SqlConnection("Data Source=(local); " +
                      "Initial Catalog=AdventureWorks; " +
                      "Integrated Security=SSPI");

    SqlCommand command =
        new SqlCommand(sqlSalesOrder, connection);

    command.Parameters.Add(
        new SqlParameter("SalesOrderNumber",
        salesOrderNumber));

    SqlDataAdapter salesOrderAdapter = new
        SqlDataAdapter(command);

    salesOrderAdapter.Fill(dsSalesOrder, "SalesOrder");
}

private void GetSalesOrderDetailData(string salesOrderNumber,
                       ref DataSet dsSalesOrder)
{
    string sqlSalesOrderDetail =
        "SELECT  SOD.SalesOrderDetailID, SOD.OrderQty, " +
        "        SOD.UnitPrice, CASE WHEN " +
        "        SOD.UnitPriceDiscount IS NULL THEN 0 " +
        "        ELSE SOD.UnitPriceDiscount END AS " +
        "        UnitPriceDiscount, SOD.LineTotal, " +
        "        SOD.CarrierTrackingNumber, " +
        "        SOD.SalesOrderID, P.Name, P.ProductNumber " +
        "FROM    Sales.SalesOrderDetail SOD INNER JOIN " +
        "        Production.Product P ON SOD.ProductID = " +
        "        P.ProductID INNER JOIN " +
        "        Sales.SalesOrderHeader SOH ON " +
        "        SOD.SalesOrderID = SOH.SalesOrderID " +
        "WHERE   (SOH.SalesOrderNumber = @SalesOrderNumber) " +
        "ORDER BY SOD.SalesOrderDetailID";

    using (SqlConnection connection = new
        SqlConnection("Data Source=(local); " +
                      "Initial Catalog=AdventureWorks; " +
                      "Integrated Security=SSPI"))
    {

        SqlCommand command =
            new SqlCommand(sqlSalesOrderDetail, connection);

        command.Parameters.Add(
            new SqlParameter("SalesOrderNumber",
            salesOrderNumber));

        SqlDataAdapter salesOrderDetailAdapter = new
            SqlDataAdapter(command);

        salesOrderDetailAdapter.Fill(dsSalesOrder,
            "SalesOrderDetail");
    }
}

请参阅)


部署和测试

概念

使用 ReportViewer 控件集成 Reporting
Services

在部署报表项目之前,需要指定将项目部署到哪一个服务器。如果您最初使用该向导创建了报表项目,那么您可能已经指定了目标服务器。

要检查该设置或指定一个新服务器,请选择“Project | Properties”来显示
Project Properties 对话框。进行该设置使您可以指定项目的文件夹名和
Reporting Services Web 服务的 URL。在菜单上选择“Build | Deploy
Solution”将构建报表项目,然后将其部署到服务器。

在部署报表项目后,您就可以进行测试了。已部署到服务器的每个报表都具有唯一的路径,该路径可以用于在浏览器中显示报表。例如,要显示您创建的第一个报表,请打开浏览器并导航到
+Project1/Products+Report。这会以 HTML
格式呈现报表并在页面的顶端显示一个工具栏,以便使您可以对报表进行翻页、更改缩放比例,甚至以各种其他格式(例如,PDF)查看报表。

您还可以通过导航到服务器上的以下
URL,来浏览已部署到服务器的所有报表项目的列表:。报表服务器提供使您可以查看已部署的报表类型和查看报表的最小的用户界面。

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图