SSRS报表服务随笔(rdl报表服务)-创建一个简单的报表
这段时间一直在敲rdl报表,在国内的不这么留在,在国外的话,还是挺流行的,国内的话,这方面的资料很少很少,也踏过不少坑
先从SSRS了解起,SSRS全称 SQL Server Reporting Services,是依赖于数据库运行的,是微软开发的重量级别的BI产品
有什么优却点呢?
因为是重量级的,所以上手容易,开发简单,有数据库服务器就可以了,不需要依赖于IIS运行,而且好像可以自动发送邮件
可扩展性比较低,(有用么,做好一个报表就直接用了,扩展的可能性本来就低),对比那些其他报表来说,确实比较好
在国内,我看到有好多友友是把rdl报表嵌在C#项目里开发的,rdl只是一个显示窗口,用C# 的各种空间做输入,其实完全用不着,微软提供的rdl报表参数挺好用的
废话不多说了,开发rdl报表,有两种方式,一种是SSDT,一种就是SSRS
在这里说下SSDT
对应的数据库版本不同,名称也有点差别,在SqlServer2008,叫做SQL Server Business Intelligence Development Studio,是集成在数据库安装包的,属于SqlServer的开发工具,同时呢,SSRS也集成在数据库安装包里,
SqlServer2012,名称忘了叫啥了,图标和名称与2008的都很相似
因为SqlServer2014没有使用过,所以,跳过
在SqlServer2016以后,画风大变,在安装选项里只有一个SSRS选项,SSDT给了Vs了,在VS2017可以安装SSDT组件
SqlServer2017呢,SSDT和SSRS都需要独立安装,不同的是,SSDT属于VS的实例,SSRS属于SQLServer的实例
在SSRS和SSDT都可以开发rdl报表,SSRS是依托于服务器开发,包括创建报表都是从服务器上操作,SSDT就像平常的开发,建立一个空的商业智能项目,开发完成后可上传到SSRS服务器,也可以直接连接SSRS服务器开发
先贴上我拿来演示的数据
CREATE TABLE STUDENT
(
GID VARCHAR(50) UNIQUE,
ID INT IDENTITY,
NAME VARCHAR(20),
SEX BIT,
CHINESE INT,
MATHEMATICS INT,
ENGLIST INT
);
GO
INSERT INTO STUDENT(GID,NAME,SEX,CHINESE,MATHEMATICS,ENGLIST) VALUES (NEWID(),'张三',0,95,90,75);
INSERT INTO STUDENT(GID,NAME,SEX,CHINESE,MATHEMATICS,ENGLIST) VALUES (NEWID(),'李四',0,95,90,75);
INSERT INTO STUDENT(GID,NAME,SEX,CHINESE,MATHEMATICS,ENGLIST) VALUES (NEWID(),'王五',1,95,90,75);
INSERT INTO STUDENT(GID,NAME,SEX,CHINESE,MATHEMATICS,ENGLIST) VALUES (NEWID(),'赵六',0,95,90,75);
GO
个人呢喜欢用SSDT开发,比SSRS好操作,更灵活
- 配置SSRS
- 先配置SSRS服务器,打开Reporting Server 配置管理器,选择报表服务器实例

- 配置账户
- 配置本地服务器,用内置账户就可以了,要是给别人用的,选择配置其他账户,在其他账户里,注意用户名是域/用户名的格式,不知道是什么的可以看看你的系统说明,保存秘钥,确认

- Web服务URL
- 在这里,点击高级,可以添加,可以修改,在以后做子报表的时候需要用这个

- 更改数据库
- 本地服务器的话,默认就好,远程服务器的话,需要报表模式为Sql账户,凭据也是

- Web门户URL
- 这个了,就随便了,这个是你SSRS报表管理页面的配置,配置完成的话,现在就可以访问了
2. 现在开始创建报表:
SSRS方式
打开你的SSRS管理页面,在右上角点击加号(新建)新建文件夹与报表,在SqlServer2012之前,点击添加报表,在2016以及2016之后,区分了移动报表,分页报表
点击加号(新建),可以新建文件夹,KPI报表,移动报表,分页报表,数据源,数据集

分页报表
新建分页报表会打开Reporting Builder,没有的话在弹出的页面选择获取Reporting Builder;
在Reporting Builder首先会给你弹出一个向导,有表格矩阵,图表,地图向导,空白报表

首先,选择创建数据集(可以使用共享数据集),
然后,创建数据源,点击新建,输入连接字符串,或是生成字符串
第三步,通过Sql完成数据集的创建,可以通过可视化操作,也可以点击编辑为文本输入sql
(在这里需要的是,字段名称不能有重复的,不能同时写两个以上的查询语句或不能包含函数操作类的语句)
第四部,分组

第五步:选择布局
SqlServer2012之前会有第六步选择样式外观
最后点击完成,这样,一个最简单的报表就出来了
SSDT方式(支持中文)
Sqlserver2012(包含)之前的版本,打开SQL Server Business Intelligence Development Studio,选择商业智能项目,创建报表服务项目
VS2017(包含)之后,打开VS,打开VS2017或VS2017 SSDT,选择商业智能项目,创建报表服务项目
你的电脑数据库为2016/2017的,VS为2017以下的,抱歉了,只能通过SSRS创建报表
选择项目路径以及名称
打开解决方案资源管理器,右击报表,选择添加新报表
选择或新建数据源,点击编辑可以生成连接字符串
输入查询的sql语句
选择表格或矩阵
分组
输入报表名称
完成
下班了,明天继续
SSRS报表服务随笔(rdl报表服务)-创建一个简单的报表的更多相关文章
- SSRS报表服务随笔(rdl报表服务)-报表参数
上一篇我们说了创建一个简单的显示报表,但在实际工作中,我们有很多要带条件的报表 现在先认识一下报表数据,首次打开SSDT,报表数据在窗口的左侧,要是找不到了,没关系,在工具栏-视图-最下面的报表数据 ...
- Java开源报表Jasper入门(2) -- 使用JasperSoft Studio创建一个简单报表
在接下来的教程中,我们将实现一个简单的JasperReports示例,展现其基本的开发.使用流程.文章很长,不过是以图片居多,文字并不多. 实例中使用最新的Jasper Studio5.2进行报表设计 ...
- DevExpress XtraReports 入门六 控件以程序方式创建一个 交叉表 报表
原文:DevExpress XtraReports 入门六 控件以程序方式创建一个 交叉表 报表 本文只是为了帮助初次接触或是需要DevExpress XtraReports报表的人群使用的,为了帮助 ...
- node创建一个简单的web服务
本文将如何用node创建一个简单的web服务,过程也很简单呢~ 开始之前要先安装node.js 1.创建一个最简单的服务 // server.js const http = require('http ...
- django创建一个简单的web站点
一.新建project 使用Pycharm,File->New Project…,选择Django,给project命名 (project不能用test命名) 新建的project目录如下: ...
- IntelliJ IDEA 15 部署Tomcat及创建一个简单的Web工程
一.部署Tomcat 二.创建一个简单的Web工程 2.1创建一个新工程 创建一个新工程 设置JDK及选择Web Application (创建的是Web工程) 点击Next,选择工作空间,起个工程名 ...
- 使用ssm(spring+springMVC+mybatis)创建一个简单的查询实例(二)(代码篇)
这篇是上一篇的延续: 用ssm(spring+springMVC+mybatis)创建一个简单的查询实例(一) 源代码在github上可以下载,地址:https://github.com/guoxia ...
- 使用ssm(spring+springMVC+mybatis)创建一个简单的查询实例(一)
梳理下使用spring+springMVC+mybatis 整合后的一个简单实例:输入用户的 ID,之后显示用户的信息(此次由于篇幅问题,会分几次进行说明,此次是工程的创建,逆向生成文件以及这个简单查 ...
- [转帖] Linux 创建一个简单的私有CA、发证、吊销证书
原创帖子地址: https://blog.csdn.net/mr_rsq/article/details/71001810 Linux 创建一个简单的私有CA.发证.吊销证书 2017年04月30 ...
随机推荐
- 关于Django Web应用架构设计开发的几个问题
1.关于分层,做过传统JEE应用的同学肯定知道JEE应用会分很多个设计层.根据传统Web应用架构设计一般从上到下分这么几个层(太懒了,不画图了):Web前端层.Web后端交互层.业务层.基础数据设施层 ...
- Ubuntu本地uwsgi配Django问题的解决
版本Ubuntu14.04,Django1.6.5 ubuntu本地Uwsgi调Django可能会报错: -- unavailable modifier requested: 0 -- 解决方法:先安 ...
- OkHttp上传文件,服务器端请求解析找不到文件信息的问题
长话短说,不深入解释了,官方给的上传案例代码: private static final String IMGUR_CLIENT_ID = "..."; private stati ...
- 任务调度利器:Celery
http://www.liaoxuefeng.com/article/00137760323922531a8582c08814fb09e9930cede45e3cc000 Celery是Python开 ...
- Ruby中如何复制对象 (deep clone)(转载)
Ruby中如何复制对象 (deep clone) 用Ruby复制一个对象(object)也许没有你想像的那么容易. 今天我google了半天, 做个总结吧. 先从最简单的开始, b = a 是复制吗? ...
- Ocelot中文文档-Qos服务质量
目前Ocelot支持一种QoS功能. 如果您希望在请求向下游服务时使用断路,则可以在ReRoute中进行设置. 这个功能使用了一个名为Polly的.NET库,这个库很棒,在这里可以找到它. 添加如下配 ...
- java8完全解读一
java8完全解读 java8完全解读前言java8的一些新特性1.为什么要用java8?1.1首先想到的逻辑应该是如下1.2使用策略模式来解这个问题1.3使用策略模式和内部类来解决问题1.4使用策略 ...
- 程序中编写log日志
public string logFile; ; private Stream s = null; StreamWriter sw = null; /// <summary> /// 用l ...
- vim快捷键汇总
命令历史 以:和/开头的命令都有历史纪录,可以首先键入:或/然后按上下箭头来选择某个历史命令. 启动vim 在命令行窗口中输入以下命令即可 vim 直接启动vim vim filename 打开vim ...
- python_黑洞数
>>> def main(n): start = 10**(n-1)+2 end = start*10-20 for i in range(start,end): i = str(i ...