[RDLC]心得整理(一)
2014年在做项目的时候, 过用过RDLC, 之后便在没有使用过了. 最近又有项目使用rdlc, 感觉有些陌生,然后重新阅读了以前的笔记,想做一下整理.
常见问题:
1. 为什么rdlc报表出来的pdf, 最后面有一页空白页?
2.有2个或多个数据源, 怎么样设置和绑定?
3.有一个表格, 里面还有一个表格, 如何做排版,使上下表格排版各自独立.
一.为什么rdlc报表出来的pdf, 最后面有一页空白页?
有的时候, 并不是下面的长度问题, 而是宽度问题, 右键=>视图=>标尺 宽度不超过16,基本A4 不会有空白页.
二.有2个或多个数据源,怎么设置绑定.
我们知道, 新建一个rdlc,里面拖入一张表,会要求创建一个数据源, 然后再拖入第二章表...诶,发现没有创建数据源选项,
有一种是先建数据源,一个字段一个字段的添加, 然后再去绑定, 我觉得这样做特别麻烦, 因为字段很多,改起来也是相当麻烦.
经过研究, 个人认为以下方式, 比较快速,而且也方便.
步骤1.首先在BLL业务逻辑层, 建好对应的 一个 返回List<T>的没有逻辑主体的方法
public List<Student>GetStudentList(){ return new List<Student>();};
public List<Teacher>GetStudentList(){ return new List<Teacher>();};
步骤2. 在解决方案目录下, 选择rdlc,右键=>打开方式=>xml(文本)编辑器打开
可以看到有 <DataSources>节点 和 <DataSets> 节点,这两个是 一一对应的.
假设我现在有 2个数据源 <DataSource Name="DataSource1"> <DataSource Name="DataSource2"> 和 <DataSet Name="DataSet1">, <DataSet Name="DataSet2">
DataSource 结构说明: 设置一个Name和 DataSourceID (必须唯一)
<DataSource Name="DataSource1">
<ConnectionProperties>
<DataProvider>System.Data.DataSet</DataProvider>
<ConnectString>/* Local Connection */</ConnectString>
</ConnectionProperties>
<rd:DataSourceID>f967ab1f-060c-4fd6-b670-a2ffbf328f9c</rd:DataSourceID>
</DataSource>
DataSet 结构说明: <Query> 里面设置的 <DataSourceName>就是 数据源 ,对应上面的 <DataSource>, 然后下面是 <Fields> 字段列表.
<Fields>节点里面是数据源的字段列表, 字段名, 数据类型. 最后面有一个 <rd:DataSetInfo>,着重说一下这个
<rd:DataSetName>是 上面所定义的方法的类所在的命名空间.
<rd:TableName>RdlcDataSource</rd:TableName>是类的名称, 我这里专门建一个类, 用于存放rdlc的数据源
<rd:ObjectDataSourceSelectMethod> 是方法的名称 , 例如返回List<T> 的方法名
<rd:ObjectDataSourceSelectMethodSignature> 这个是 对返回List<T>的方法, T 的解释 ,如下表示 是一个List, T的类型是 PdfLibrary.Models.Cfxx (命名空间.类名), 方法名是 GetCfxxList
==> System.Collections.Generic.List`1[PdfLibrary.Models.Cfxx] GetCfxxList(System.Collections.Generic.List`1[PdfLibrary.Models.Cfxx])
<rd:ObjectDataSourceType> 对"类" 对象的说明; 该类是 PdfLibrary.dll下, 类的全名称是 PdfLibrary.CreatePdfTemp.RdlcDataSource
==> PdfLibrary.CreatePdfTemp.RdlcDataSource, PdfLibrary, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
<DataSet Name="DataSet1">
<Query>
<DataSourceName>DataSource1</DataSourceName>
<CommandText>/* Local Query */</CommandText>
</Query>
<Fields>
<Field Name="cfbm">
<DataField>cfbm</DataField>
<rd:TypeName>System.String</rd:TypeName>
</Field>
<Fields>
<rd:DataSetInfo>
<rd:DataSetName>PdfLibrary.CreatePdfTemp</rd:DataSetName>
<rd:TableName>RdlcDataSource</rd:TableName>
<rd:ObjectDataSourceSelectMethod>GetCfxxList</rd:ObjectDataSourceSelectMethod>
<rd:ObjectDataSourceSelectMethodSignature>System.Collections.Generic.List`1[PdfLibrary.Models.Cfxx] GetCfxxList(System.Collections.Generic.List`1[PdfLibrary.Models.Cfxx])</rd:ObjectDataSourceSelectMethodSignature>
<rd:ObjectDataSourceType>PdfLibrary.CreatePdfTemp.RdlcDataSource, PdfLibrary, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null</rd:ObjectDataSourceType>
</rd:DataSetInfo>
绑定列表:
<DataSources> 的第一个节点, 最好设置成,用来绑定 表格的. , 后面可以直接使用 <Value>=Fields!cfbm.Value</Value> 来绑定字段,
这里的 Fields 默认指的就是 第一个数据源DataSet1 里面的字段.
绑定文本字段:
如果单独绑定某一个文本框 <Value>=First(Fields!cfbm.Value, "DataSet1")</Value> ,
如果要用到 第二个数据源, 绑定某一个文本框, 要这样使用, 指定 <Value>=First(Fields!cfxx_sjfw.Value, "DataSet2")</Value>
备注说明:
一个 表 对象, 里面只能设置一个数据源, 如果有不同的数据源, 需要拆分出来, 单独创建一个表,单独选择 DataSetName
小技巧:
当有多个数据源的时候, 新建一个空白的 rdlc,然后 放一张 表, 会选择数据源, 然后将这个里面的 dataset 里面的配置, 拷贝过去,更改 datasource 就行了.
[RDLC]心得整理(一)的更多相关文章
- (转)Mysql数据库主从心得整理
Mysql数据库主从心得整理 原文:http://blog.sae.sina.com.cn/archives/4666 管理mysql主从有2年多了,管理过200多组mysql主从,几乎涉及到各个版本 ...
- 心得整理之一--RDLC多数据源多表
我将项目中的一部分提炼出来,写了这个Demo. 先说一下需求, 从 API接口, 获取数据源, 调用RDLC 生成PDF文件. (后面还有涉及到使用福昕PDf阅读器进行设置文件自定义内容,以供外部程序 ...
- Mysql数据库主从心得整理
管理mysql主从有2年多了,管理过200多组mysql主从,几乎涉及到各个版本的主从,本博文属于总结性的,有一部分是摘自网络,大部分是根据自己管理的心得和经验所写,整理了一下,分享给各位同行,希望对 ...
- maven学习心得整理
maven的学习心得 已经接触了maven项目有一段时间了,开始时仅仅会使用,在使用中发现了它的强大和方便,于是决心研究一下: 首先,普及一下maven参数: -D:传入属性参数 -P:使用POM中指 ...
- WEB网站测试心得整理
一.输入框: 1.正常的字母/文字/数字(正常流程的测试): 2.重复提交(输入内容后,重复点击提交按钮): 3.纯异常字符/正常输入夹杂异常字符(!@#¥%……&**等等): 4.长度限制( ...
- 自学java一路以来,心血心得整理分享
✿ 贴心提示:文章内容比较长,但都是干货,请大家耐心看完.时间不够充裕的小伙伴,建议收藏,一定要耐心看完,保证对你有后续学习java有所帮助. 一.推荐背景介绍 (一)我是怎么学的? ★ 非常普通的人 ...
- android最近心得整理
activity中OnAttachedWindow生命周期在OnResume之后,所以对长宽获取在推荐在OnAttachedWindow中进行. onDetachedWindow是在OnDestroy ...
- IDEA使用心得整理
[演出模式] 我们可以使用[Presentation Mode],将IDEA弄到最大,可以让你只关注一个类里面的代码,进行毫无干扰的coding. 可以使用Alt+V快捷键,弹出View视图,然后选择 ...
- 定时器setTimeout()和setInterval()使用心得整理
JavaScript提供定时执行代码的功能,叫做定时器(timer),主要由setTimeout()和setInterval()这两个函数来完成. 一.setTimeout() setTimeout函 ...
随机推荐
- IDEA中jsp页面写out.println会报错?
解决办法: (1)在WEB-INF目录下新建一个lib目录,并把Tomcat安装目录下的如下两个jar包复制过来. (2)选择jsp-api.jar,右键,Add as Library. (3)在Fi ...
- 圆环进度css
看效果先:http://sandbox.runjs.cn/show/b6bmksvn 参考: jquery圆环百分比进度条制作 CSS clip:rect矩形剪裁功能及一些应用介绍 CSS clip: ...
- Oracle 11g服务OracleDBConsoleorcl启动失败(异常或报错)
OracleDBConsoleorcl:Oracle数据库控制台服务,orcl是Oracle的实例标识,默认的实例为orcl.在运行Enterprise Manager(企业管理器OEM)的时候,需要 ...
- tomcat的热部署配置
1.什么是tomcat热部署? 所谓的tomcat热部署,就是在不重启tomcat服务器的前提下,将自己的项目部署到tomcat服务器中,这种方式是非常方便的,也称之为“开发即用”,热部署分为手动热部 ...
- linux系统安全加固--账号相关
linux系统安全加固 一.账号相关 1.禁用或删除无用账号 减少系统无用账号,降低安全风险. 当我们的系统安装完毕后,系统默认自带了一些虚拟账户,比如bin.adm.lp.games.postfix ...
- liunx 内置mail 发送邮件
邮件配置文件/etc/mail.rc [root@ ~]# vim /etc/mail.rc #添加.修改如下内容 .com .com .com set smtp-auth-password=xxx ...
- C语言利用指针排序与选择排序算法
//读入字符串,并排序字符串 #include <stdio.h> #include <string.h> #define SIZE 81 #define LIM 20 #de ...
- GIL 线程池 进程池 同步 异步 阻塞 非阻塞
1.GIL 是一个全局解释器锁,是一种互斥锁 为什么需要GIL锁:因为一个python.exe进程中只有一份解释器,如果这个进程开启了多个线程都要执行代码 多线程之间要竞争解释器,一旦竞争就有可能出现 ...
- zabbix 告警 JXM
告警 虚拟机上网 [root@test1 alertscripts]# route -n [root@test1 alertscripts]# route add default gw 172.25. ...
- 使用 maven 打包 src/test/java下的文件,并用 java jar 跑打包出来的jar
https://blog.csdn.net/nba_2011/article/details/71296745