码迷,mamicode.com
首页 > 数据库 > 详细

RDLC报表显示存储于数据库的图片

时间:2017-11-04 11:17:00      阅读:219      评论:0      收藏:0      [点我收藏+]

标签:预览   turn   cdc   sed   logs   file   reporting   分享   sel   

图片以二进制存储于数据库表中。在显示RDLC报表时,把图片呈现出来。

好吧。

把存储过程写好:
技术分享

技术分享
CREATE PROCEDURE [dbo].[usp_File_Select]
AS
SELECT [Afd_nbr],[Picture],[PictureType],[FileExtension] FROM [dbo].[ApiFileDemo]
GO
Source Code

 

在网站中,创建一个实体,是程序从数据库获取数据:
技术分享

技术分享
 public DataTable GetFiles()
        {
            sp.ConnectionString = DB.SqlConnectionString();
            sp.Parameters = null;
            sp.ProcedureName = "usp_File_Select";
            return sp.ExecuteDataSet().Tables[0];
        }
Source Code



为站点添加一个rdlc报表,参考下面步骤:
技术分享

 
细节如下:
在报表视图中,添加Table:
技术分享

技术分享

 

 为表格选择数据字段:
技术分享

 

报表设计完成。现在创建一个ASPX网页来呈现这个RDLC报表:
技术分享

紧跟下来,是在ASPX.cs写程序:
技术分享

 

技术分享
 private void Data_Binding()
    {
        this.ReportViewer1.Reset();
        this.ReportViewer1.LocalReport.Dispose();
        this.ReportViewer1.LocalReport.DataSources.Clear();

        Microsoft.Reporting.WebForms.ReportDataSource rds = new Microsoft.Reporting.WebForms.ReportDataSource();
        rds.Name = "FileDataSet";

        FileEntity fe = new FileEntity();
        rds.Value = fe.GetFiles();

        this.ReportViewer1.LocalReport.ReportPath = Server.MapPath("~/Rdlc/ImageRpt.rdlc");
        this.ReportViewer1.LocalReport.DataSources.Add(rds);
        this.ReportViewer1.LocalReport.Refresh();
    }
Source Code

 

预览一下看看结果如何:

 技术分享


数据没有显示出来,一直不停在Loading...

看来我们写少了程序,Insus.NET修改一下吧:
技术分享

 


哈,哈,显示出来了:
技术分享

 

虽然数据显示出来,但是在第二列中,图片没有显示,却显示#Error。还没有成功,还得继续努力:
技术分享


最后看到想要的结果,图片显示出来了:
技术分享

 

RDLC报表显示存储于数据库的图片

标签:预览   turn   cdc   sed   logs   file   reporting   分享   sel   

原文地址:http://www.cnblogs.com/insus/p/7778936.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!