文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
php爱好者> php文档>ReportView报表实现带参数存储过程创建报表以及为rdlc传递参

ReportView报表实现带参数存储过程创建报表以及为rdlc传递参

时间:2011-03-16  来源:itcfj

ReportView报表实现带参数存储过程创建报表以及为rdlc传递参 收藏

以下操作在环境:Windows2003 R2 + .NET2.0 + IIS6 + MS SQL2000 + VS2005(en)

先来看一个表结构

Create Table Test
(
PID varchar(100),
PName varchar(100),
PQty int,
PPrice money
)

创建一个存储过程

CREATE PROCEDURE procTest
@condition varchar(1000)
AS
DECLARE @sql varchar(8000)
SET @sql = 'SELECT PID, PName, PQty FROM Test '
IF @condition <> ''
   SET @sql = @sql + @condition
EXEC(@sql)

这里需要说明的是,我看MSDN和网上的例子使用的都是直接SELECT语句带参数的存储过程,但很多时候都需要通过构造SQL语句进行查询,所以我这里主要讲的是如何使用EXEC这样构造SQL语句的存储过程。

建一 ASP.NET WebApplication,在App_Code目录(没有的话可以右键选择 Add ASP.NET Folder新建此目录)里增加一个新项,并选择DataSet,填写DataSet名,点击确定。

在打开的窗口中右键选择Add再选择TableAdapter,弹出TableAdapter连接向导对话框,连接数据库(这个过程略),选择 Use existing stored procedrues(已存在的存储过程),点击下一步,选择procTest,直接点完成,这样一个TableAdapter算是建好了。

如果那个存储过程直接是SELECT PID, PName, PQty FROM Test 那建好的TableAdapter就会直接把PID, PName, PQty 当作列显示出来,但用的是EXEC所以要手工将PID, PName, PQty 在右键->新建Column里把这几个加进去,加完后,存盘,然后新建一个Report文件,新建完后,在Report窗口左侧会把刚刚建的 TableAdapter显示出来,把PID, PName, PQty 列拖到Report窗口中,布局自己搞定,存盘。

打开Default.aspx文件(自己新建一个都没所谓),在Toolbox里的Data中将ReportView控件拖到窗口上,选择刚刚新建的Report文件,然后再拖一个Textbox和一个Button,双击Button打开Code窗口填写代码

view plaincopy to clipboardprint?

  1. protected void Button1_Click(object sender, EventArgs e)  
  2. {  
  3. string condition = "";  
  4. if ( Textbox1.Text.Trim() != "" )  
  5. {  
  6.    string condition = "PID = '" + Textbox1.Text.Trim() + "'";  
  7. }  
  8.   
  9. //清除数据源原参数  
  10. ObjectDataSource1.SelectParameters.Clear();  
  11. //增加数据源参数  
  12. ObjectDataSource1.SelectParameters.Add("condition", condition);  
  13. //让ReportView重新加载数据源  
  14. ReportViewer1.LocalReport.Refresh();  
  15. }  

protected void Button1_Click(object sender, EventArgs e) { string condition = ""; if ( Textbox1.Text.Trim() != "" ) { string condition = "PID = '" + Textbox1.Text.Trim() + "'"; } //清除数据源原参数 ObjectDataSource1.SelectParameters.Clear(); //增加数据源参数 ObjectDataSource1.SelectParameters.Add("condition", condition); //让ReportView重新加载数据源 ReportViewer1.LocalReport.Refresh(); }

以下操作在环境:Windows2003 R2 + .NET2.0 + IIS6 + MS SQL2000 + VS2005(en)

先来看一个表结构

Create Table Test
(
PID varchar(100),
PName varchar(100),
PQty int,
PPrice money
)

创建一个存储过程

CREATE PROCEDURE procTest
@condition varchar(1000)
AS
DECLARE @sql varchar(8000)
SET @sql = 'SELECT PID, PName, PQty FROM Test '
IF @condition <> ''
   SET @sql = @sql + @condition
EXEC(@sql)

这里需要说明的是,我看MSDN和网上的例子使用的都是直接SELECT语句带参数的存储过程,但很多时候都需要通过构造SQL语句进行查询,所以我这里主要讲的是如何使用EXEC这样构造SQL语句的存储过程。

建一 ASP.NET WebApplication,在App_Code目录(没有的话可以右键选择 Add ASP.NET Folder新建此目录)里增加一个新项,并选择DataSet,填写DataSet名,点击确定。

在打开的窗口中右键选择Add再选择TableAdapter,弹出TableAdapter连接向导对话框,连接数据库(这个过程略),选择 Use existing stored procedrues(已存在的存储过程),点击下一步,选择procTest,直接点完成,这样一个TableAdapter算是建好了。

如果那个存储过程直接是SELECT PID, PName, PQty FROM Test 那建好的TableAdapter就会直接把PID, PName, PQty 当作列显示出来,但用的是EXEC所以要手工将PID, PName, PQty 在右键->新建Column里把这几个加进去,加完后,存盘,然后新建一个Report文件,新建完后,在Report窗口左侧会把刚刚建的 TableAdapter显示出来,把PID, PName, PQty 列拖到Report窗口中,布局自己搞定,存盘。

打开Default.aspx文件(自己新建一个都没所谓),在Toolbox里的Data中将ReportView控件拖到窗口上,选择刚刚新建的Report文件,然后再拖一个Textbox和一个Button,双击Button打开Code窗口填写代码

view plaincopy to clipboardprint?

  1. protected void Button1_Click(object sender, EventArgs e)  
  2. {  
  3. string condition = "";  
  4. if ( Textbox1.Text.Trim() != "" )  
  5. {  
  6.    string condition = "PID = '" + Textbox1.Text.Trim() + "'";  
  7. }  
  8.   
  9. //清除数据源原参数  
  10. ObjectDataSource1.SelectParameters.Clear();  
  11. //增加数据源参数  
  12. ObjectDataSource1.SelectParameters.Add("condition", condition);  
  13. //让ReportView重新加载数据源  
  14. ReportViewer1.LocalReport.Refresh();  
  15. }  

Reportview 动态绑定数据 收藏

.net frame work 3.5 ReportView
1.建立rdlc文件,设计UI,绑定字段.新建一个dataset做数据源,主要是数据是临时的不需要持久化.
2.建立winform页面,拉一个MicrosoftreportViewer,选择一个新建的*.rdlc文件报表.
3.数据绑定,就是推拉模型,绑定报表要呈现的数据字段,绑定数据源
绑定代码:
reportViewer1.LocalReport.DataSources.Clear();
this.reportViewer1.LocalReport.DataSources.Add(new Microsoft.Reporting.WinForms.ReportDataSource("dsNotice_Notice",

data.Notice));
this.reportViewer1.LocalReport.DataSources.Add(new Microsoft.Reporting.WinForms.ReportDataSource("dsNotice_Details",

data.Details));
this.reportViewer1.RefreshReport();

数据源名称:集合_表 dataset_table,如:dsNotice_Notice.
数据源的值:表对象.
多张表就add多次.
每次绑定前最好先清空下datasources.

打印:报表宽大于高默认横向打印,反之为纵向打印。

相关阅读 更多 +
排行榜 更多 +
找茬脑洞的世界安卓版

找茬脑洞的世界安卓版

休闲益智 下载
滑板英雄跑酷2手游

滑板英雄跑酷2手游

休闲益智 下载
披萨对对看下载

披萨对对看下载

休闲益智 下载