【水晶报表内功心法】--PULL模式样板招式

阿泰 2009-06-26 05:25:56
加精
索引

.【水晶报表内功心法】--序言
.【水晶报表内功心法】--推拉之间
============================================================
在前一篇中,讲解了PULL和PUSH模式的区别。
本节中主要是从无到有地讲解一下如何使用PULL模式来做一个报表。
因本文主要针对初学者,所以每个步骤都抓了图。

以 Web应用为例

首先,新建一个Asp.net CrystalReports站点


稍等一会后会出来一个默认的水晶报表向导


确定后,选择“创建新连接”


这里我用的是Oracle数据库,填写数据库参数


连接成功会,会显示数据库中的表,选需要的表,点到右边的框中


进入下一界面,把要显示的字段点到右边的框中


直接点“完成”(后面还有一些步骤,暂时用不着)进入模板界面


因为是直连数据库的,所以我们能马上看到实际的效果,点模板下面的“主报表预览”


至此,我们没有编写任何代码。

运行一下看看,呀!有这个提示,而且输入框不让输入


代码上场(实质上代码也有好几种写法,不过原理基本一样,此处可直接照搬,等以后大家熟悉了再自行尝试吧)


using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using CrystalDecisions.Shared;
using CrystalDecisions.CrystalReports.Engine;
using CrystalDecisions.Web;

public partial class _Default : System.Web.UI.Page
{
//水晶报表对象
private ReportDocument myReport;

private void ConfigureCrystalReports()
{


// 定义ReportDocument对象,装载Crystalreport1.rpt
myReport = new ReportDocument();
string reportPath = Server.MapPath("Crystalreport1.rpt");
myReport.Load(reportPath);


//定义水晶报表的数据库连接信息
ConnectionInfo connectionInfo = new ConnectionInfo();
connectionInfo.DatabaseName = "user";
connectionInfo.UserID = "pwd";
connectionInfo.Password = "****";
connectionInfo.ServerName = "myoraServer";

//将数据库信息传递给报表
SetDBLogonForReport(connectionInfo, myReport);

//把模板对象赋给报表前端呈现控件CrystalReportViewer1
CrystalReportViewer1.ReportSource = myReport;
}

private void SetDBLogonForReport(ConnectionInfo connectionInfo, ReportDocument reportDocument)
{
Tables tables = reportDocument.Database.Tables;

foreach (CrystalDecisions.CrystalReports.Engine.Table table in tables)
{
TableLogOnInfo tableLogonInfo = table.LogOnInfo;
tableLogonInfo.ConnectionInfo = connectionInfo;
table.ApplyLogOnInfo(tableLogonInfo);

}
}
// 注意:将代码防到Page_Init或Page_Load 中
//VS2008必须放到Page_Init中
private void Page_Init(object sender, EventArgs e)
{
ConfigureCrystalReports();
}
}



再运行一下,好了。


很简单吧,呵呵。
通过更改代码里的数据库连接,可以切换到不同的数据库上去
前提是,目标库中用到的表名及结构要是一样的。

常见问题:

出现


这个图中的提示

一般是因为数据库信息输入错误或数据库停机导致的。

预告:PUSH模式之样板操作


PS:
一种更简单的方法:
//主报表
myReport.SetDatabaseLogon("user", "pwd", "server", "db");
//子报表
myReport.Subreports[0].SetDatabaseLogon("user", "pwd", "server", "db");
...全文
11084 55 打赏 收藏 举报
写回复
55 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
e_zhiwen 2012-08-20
不是不显示图片,是用了chome的浏览器不显示图片。
  • 打赏
  • 举报
回复
yangguosheng 2012-07-25
用C#代码怎么判断报表是拉模式还是退模式?
  • 打赏
  • 举报
回复
shishuiwuhenmo 2012-05-16
问一下,出现图中的最后一个问题后该怎样解决呢,就是您请求的报表需要更多信息.
  • 打赏
  • 举报
回复
demonhello 2012-04-12
请问一下楼主一下问题 怎么解决啊? 针对数据库厂商代码:17 能大概说一下那地方的错吗? 我菜鸟水平啊

未能打开该连接。
详细资料: [数据库厂商代码:17] 未能打开该连接。
CssEb01a {D4E59299-9C14-4678-B447-231F117E7014}.rpt
详细资料: [数据库厂商代码:17]

  • 打赏
  • 举报
回复
yuduo1112 2011-12-08
[Quote=引用 18 楼 llsen 的回复:]
我的创建新连接下面怎么这么少那?
[/Quote]
我的也是这样啊,而且我用的是oracle 11g,我该怎么连接啊
  • 打赏
  • 举报
回复
xuxiaotangtang 2011-12-07
真的很好,初学者学习了...
  • 打赏
  • 举报
回复
cywmxrfzl 2011-10-10
怎么图片都不出来呢。。。。。
  • 打赏
  • 举报
回复
蝜蝂 2011-08-23
学习中!
  • 打赏
  • 举报
回复
Jessie丢 2011-07-25
来学习了、
  • 打赏
  • 举报
回复
XiaoDai27670 2011-07-25
不錯,學習中......
  • 打赏
  • 举报
回复
willy2013 2010-11-26
讲的很好,很实用!
收藏了,感谢阿泰的无私。
  • 打赏
  • 举报
回复
houhou814 2010-11-26
收藏了,感谢阿泰的无私。
  • 打赏
  • 举报
回复
lxgtmac 2010-11-04
收藏了。。。
  • 打赏
  • 举报
回复
shixiheng 2010-10-30
过滤中
  • 打赏
  • 举报
回复
reason159 2010-08-26
对初学者来说很不错,学习了
  • 打赏
  • 举报
回复
xjyyaqy 2010-07-13
顶上去
  • 打赏
  • 举报
回复
t19881128 2010-06-30
很棒啊
  • 打赏
  • 举报
回复
我是一道光_ 2010-06-05
看到,学习了。

  • 打赏
  • 举报
回复
风扬 2010-04-23
学习了,最近在做水晶报表 受益非浅
  • 打赏
  • 举报
回复
baobingbing 2010-03-15
顶泰哥。。。
楼上兄弟就照着画就好了,我也是看oracle 的例子做的sql server ,我想问下在push下怎么显示图片呢?
  • 打赏
  • 举报
回复
加载更多回复
相关推荐
发帖
图表区
加入

4810

社区成员

.NET技术 图表区
社区管理员
  • 图表区社区
申请成为版主
帖子事件
创建了帖子
2009-06-26 05:25
社区公告
暂无公告