Reporting Service for SQL server 2000预览研究

By Ben


Reporting Service + SP1 for SQL server 2000预览研究

环境: WinXP, SQL Server 2000 + SP<?xml:namespace prefix = st1 ns = "urn:schemas-microsoft-com:office:smarttags" /><chmetcnv w:st="on" unitname="a" sourcevalue="3" hasspace="False" negative="False" numbertype="1" tcsc="0">3A</chmetcnv>, .Net 1.1<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

附件: (下载附件)

Project: Reporting Service 报表设计的Project

Setup: 报表程序发布安装程序

Web: Reporting ServiceWeb应用

Win: Reporting ServiceWin应用

研究思路:

1. 了解熟悉Reporting Service各个基本概念

2. 安装运行Reporting Service

3. 配置Reporting Service设置

4. 设计报表

5. 实现.Net程序调用报表

6. 实现安装发布报表

概述

Reporting Service与大家熟悉的水晶报表是同一类东西: 报表工具.

基于Sql Server 2000, 结合VS.NET强大的设计器可以轻松实现报表制作

Reporting Service组件:

1. Web 报表管理器 (http://localhost/Reports)

2. VS.NET报表设计器

3. 报表Web Service (http://localhost/ReportServer/ReportService.asmx)

4. Reporting ServiceWeb端站点 (http://localhost/ReportServer)

报表主要构成:

数据源(RDS) 配置数据库连接串. 是一个标准xml文件

报表(RDL) 配置sql语句, 报表样式. 也是一个标准xml文件

1. 安装

需求环境: Sql Server 2000 + SP<chmetcnv w:st="on" unitname="a" sourcevalue="3" hasspace="False" negative="False" numbertype="1" tcsc="0">3A</chmetcnv>

安装过程中可以设置组件1, 组件4Web路径 (本研究过程设置默认路径)

过程略

2. 配置

进入 Web 报表管理器 (http://localhost/Reports)

A.管理用户

用户角色分:

发布者 可以将报表和链接报表发布到报表服务器。

浏览者 可以查看文件夹、报表和订阅报表。

内容管理员 可以管理报表服务器中的内容。包括文件夹、报表和资源。

我的报表 可以发布报表和链接报表;管理用户的 My Reports 文件夹中的文件夹、报表和资源。

用户权限设置与我们熟悉的SharePoint很相似, 可以设置报表Web端站点的权限和某个报表的权限.

不同的是, Reporting Service权限设置可以结合Sql的用户设置来实现更具体的权限分配

关键是报表的数据源连接要以Windows身份验证(目的是将Web访问的Windows身份带到Sql), 不能为sa用户

B.报表的订阅

这点与SharePoint也很相似, 可以将订阅一些报表. (具体实现在本次研究中略过)

C.报表的历史

可以实现快照功能, 可以手工创建snapshot, 也可以实现无人操作--设定snapshot计划自动创建snapshot. (具体实现在本次研究中略过)

D. 报表的"执行"设置

可以设置报表的数据缓冲, 执行时间(超时时间). (具体实现在本次研究中略过)

此外, 可以上传rds, rdl(数据源, 报表). 由于它们只是xml文件, 所以可以很灵活.

ReportingServicesService.exe这个window service解析

3. 设计报表

1) 运行vs.net

2) 创建项目 ->

3) (此时可以从项目模板分类里有"智能商业项目"里的列表中看到有一项是Reporting Service项目模板的)选取Reporting Service项目模板并创建

创建报表可以使用向导创建, 高级点的也可以手工创建

项目会自动生成两个Folder: 共享数据源, Reports

这里介绍手工创建主要过程:

A. 新建数据源. Folder共享数据源里利用右键添加新项来创建数据源, 它会自动生成一个rds文件

B. 新建报表. 同样, 利用右键添加新项创建报表, 它会自动生成一个rdl文件. 在这里我们可以像设计asp.net页面一样来设计报表样式

C. 发布/部署到Reporting ServiceWeb端站点.

首先打开报表的project属性看看:

OverwriteDatasources: true|false 部署时是否覆盖现在的rds数据源

TargetFolder: 部署到Reporting ServiceWeb端站点的报表的目录, 比如输入DemoProject, 需要在http://localhost/ReportServer/DemoProject下访问部署的报表

TargetServerURL: 部署到Reporting ServiceWeb端站点的Web路径

StartItem: 这个是运行在vs.net上的, Ctrl + F5运行报表Project的报表启动项

4. .NET程序调用报表 (实例请看附件)

方式一: 也是最简单的调用, 就是直接用Brower打开Reporting ServiceWeb端站点的报表.

可以通过URL参数作为报表的输入参数, 具体的请看附件Web项目的DynamicQuery.rdl

方式二: 通过调用Reporting Service提供的Web Service. 它已经提供有若干的Web method供调用

5. 发布安装报表

安装Reporting Service后会有个rs.exe工具. 路径"%SYSTEMDRIVE%\Program Files\Microsoft SQL Server\80\Tools\Binn\RS.exe"

可以看看rs.exehelp, 它支持几个特定的参数, 利用.rss脚本实现将rdl, rds发布安装到Web端站点

经研究已经设计出一个Setup程序. 见附件Setup目录

总结:

感觉上,

Reporting Server的缺点:

Reporting Service报表设计上还有些不成熟

设计报表不方便; Web端浏览报表必经导出后才可以打印; 有些设置的东西无效(这点好比设置asp.netSession生存时间时灵时不灵的现象);

复杂的报表(比如嵌套的子报表, 如附件里的supplier.rdl)查询慢.

虽如此, Reporting Service还是一个比较Cool 的报表工具,

可取之处也正是如上介绍它的一些的特点

你可能感兴趣的:(sql,Web,SQL Server,asp.net,SharePoint)