vs ReportViewer 报表控件

简介: 引用:http://www.cnblogs.com/akak123/archive/2012/08/27/ReportViewer.html ReportViewer是vs自带控件。今天在此说明下他的用法,主要是感觉网上资料有点少。

引用:http://www.cnblogs.com/akak123/archive/2012/08/27/ReportViewer.html

ReportViewer是vs自带控件。今天在此说明下他的用法,主要是感觉网上资料有点少。晒一点希望对大家有所帮助。

其实他的使用步骤十分简单:

1 托入相应的控件(ReportViewer,和 *.rdlc类型的文件)

2 关联数据

3 加上ajax

 

 

1.托入相应的控件

对应拖入2个控件后, rdlc中用拖拉设置报表的布局,并设置数据源。

在rdlc中的设置中 有足够多的图表类型选择

 

并且可在图中圆圈处拖入字段,表示系列或者轴内容

 

2关联数据

数据源拖入后,用一下方式可查看.rdlc文件。事实上他把布局的所有细节转化为xml来表示。

所有如果你想要自定义数据源也成为可能

 

 

关于自定义数据源

首先你需要在.rdlc中设置好报表的外形。然后你可以在页面后台指定数据源。

View Code
复制代码
 protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack) {
            
             DataClasses1DataContext _dc = new DataClasses1DataContext();
            var _data = _dc.zwgxx22(DateTime.Parse("2012-1-1"), DateTime.Parse("2012-8-23"));
            DataTable dt = new DataTable("dataset");
            dt.Columns.Add("MaxUpSpeed",typeof(int));  //列 务必带上数据类型 否则无法显示报表内容,并和rdlc上的数据源完全相同
            dt.Columns.Add("MaxDownSpeed", typeof(int));
            dt.Columns.Add("MinUpSpeed", typeof(int));
            dt.Columns.Add("MinDownSpeed", typeof(int));
            dt.Columns.Add("AvgUpSpeed", typeof(int));
            dt.Columns.Add("Datetime", typeof(DateTime));
            dt.Columns.Add("AvgDownSpeed", typeof(int));
            foreach (var item in _data)
            {
            
                dt.Rows.Add(new object[] { 
                        item .AvgDownSpeed,item.MaxDownSpeed,item.MinDownSpeed,
                        item.MinUpSpeed,item.AvgUpSpeed,item.Datetime,item.MaxUpSpeed});
            }
            ReportDataSource _rpdata = new ReportDataSource("DataSet2", dt);  
            this.ReportViewer1.LocalReport.DataSources.Clear();
//清理原来数据源
            this.ReportViewer1.LocalReport.DataSources.Add(_rpdata);//绑定新数据源
            ReportViewer1.LocalReport.Refresh();//刷新
            
            }
           

        }
 
复制代码

注意点:

如果是自定义数据源,在.rdlc中设置的数据源元素需要和后台设置层次对应,即在.rdlc的xml表示中DataSource和dataSet必须对应自定义数据源datatable中的 ReportDataSource _rpdata = new ReportDataSource([DataSource], dt);和 DataTable dt = new DataTable([dataSet]);

如果不是自定义数据源,只要拖拉就能完成报表的显示:

3 ajax


完成以上操作后需要在reportviewer外头套一个scriptManager  和updatepanel(必须)。因为他需要用脚本包装和回发

 

 

希望对大家有所帮助吧

相关文章
|
9天前
|
人工智能 运维 安全
|
7天前
|
人工智能 异构计算
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
|
9天前
|
机器学习/深度学习 人工智能 自然语言处理
B站开源IndexTTS2,用极致表现力颠覆听觉体验
在语音合成技术不断演进的背景下,早期版本的IndexTTS虽然在多场景应用中展现出良好的表现,但在情感表达的细腻度与时长控制的精准性方面仍存在提升空间。为了解决这些问题,并进一步推动零样本语音合成在实际场景中的落地能力,B站语音团队对模型架构与训练策略进行了深度优化,推出了全新一代语音合成模型——IndexTTS2 。
711 23
|
8天前
|
人工智能 测试技术 API
智能体(AI Agent)搭建全攻略:从概念到实践的终极指南
在人工智能浪潮中,智能体(AI Agent)正成为变革性技术。它们具备自主决策、环境感知、任务执行等能力,广泛应用于日常任务与商业流程。本文详解智能体概念、架构及七步搭建指南,助你打造专属智能体,迎接智能自动化新时代。
|
人工智能 数据可视化 数据挖掘
Quick BI 体验&征文有奖!
瓴羊生态推出Quick BI 征文激励计划,鼓励用户分享数据分析实践经验与技术洞察,征集高质量原创文章。内容围绕AI功能体验与BI案例实践,设季奖、年奖及参与奖,优秀作者可获现金奖励、产品内测资格及官方认证形象。投稿截止至2026年3月31日。
Quick BI 体验&征文有奖!