初学水晶报表的一点想法:编程构造水晶报表??

honkerboy07 2004-03-29 04:18:02
是否可以这样构造水晶报表:
建一个空报表rtp,然后在程序里load, 再生成一个reportdocument,并给 这个reportdocument 设置 字段名、数据、格式, 然后绑定reportdocument和报表——这样能不能得到一个客户需要的报表呢??

好像说得不够清楚,其实我是想这样:用sql语句得到一个dataset, 然后根据dataset所包含的字段及其对应的数据,添加显示到空报表上——也就是说不要报表模板,报表上的所以字段和数据都由自己编程设置, 不知道这个想法行得通不???有没有例子啊???
...全文
130 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
honkerboy07 2004-06-18
  • 打赏
  • 举报
回复
此贴本已结,
论坛改社区,
数据全复原,
郁闷,结贴!
happyjun2000 2004-06-18
  • 打赏
  • 举报
回复
to polarlm(今年本命年)
我想用一个变化的dastaet来作为数据源,但是在报表设计的时候一定要指定一个已经存在的固定的dataset作为数据源。
怎么解决呢?
0Modest 2004-06-18
  • 打赏
  • 举报
回复
有个老外写的.net下reportprint的控件里有详细方法。发个给你吧。
feic 2004-03-30
  • 打赏
  • 举报
回复
o
polarlm 2004-03-30
  • 打赏
  • 举报
回复
如果你想改报表的数据源的话,因为有好多操作都是在做报表的时候完成的,例如更改字段,所以我想你可以试试集成报表设计器到你的程序中去
你也可以参考一些继承报表设计器的资料
不过偶觉得没有必要如此
我以前也想过新建一个reportDocument,然后一步步,想添加一个什么东东,就写一些代码,但是不现实。
水晶报表是个比较成熟的软件,它不会像windows forms一样,添加一个什么东东,在代码里面都能够看到,它已经封装好了。
sunruping 2004-03-30
  • 打赏
  • 举报
回复
步骤一:看示例文件
水晶报表自带一个示例文件,数据库是access(不带密码的)。我首先运行示例文件(基于webform和winform)结果显示了正确的报表,正如“飞刀”的示例。
于是,建立了一个报表文件和.aspx文件,结果显示登陆失败!把报表文件换成示例的报表文件,不再出错。
问题出在什么地方?难道是报表格式文件有关于登陆权限的设置?通过跟踪、调试,报表文件和示例报表文件,没有发现任何的不同。看来问题不在报表文件。
是数据库的问题?我建立一个access结果还是登陆失败!
不是数据库的问题(我自己的数据库是未带密码的access,帮助中的数据库也是如此)?也不是报表格式文件的问题(我仔细分析了两者的原代码是相同的)?
那么问题出现在什么地方?我白思不得其解!
步骤二:找帮助文件

通过 Crystal Reports for Visual Studio .NET 访问安全数据库的过程在 Web 窗体和 Windows 窗体之间有所不同。在 Windows 窗体中,对话框自动提示用户输入用户名和密码(测试很容易成功)。而在 Web 窗体中,需要设计一个表单以从用户获取该信息。对于这两种情况,均可使用代码来指定用户名和密码,从而为应用程序的所有用户提供相同的安全等级。

对同样的数据库(先是用帮助示例中的access数据库,后来用自己建立的access数据库)。发现对于同一个报表文件,对于winform能显示成功,而对于webform则仍然显示登陆失败!
看来问题是出在权限的设置上。

步骤三:研究帮助,终于成功!
找到“设置数据库登录参数”字样,里面提供了一些后来发现是非常有用的信息:
下列示例说明如何将登录参数传递到报表的表中。该示例使用到某个安全的 SQL Server 数据库的连接。

启动一个新项目
向窗体添加一个“按钮”和四个“文本框”控件。
将“文本框”控件分别命名为:serverNameTxt、dbNameTxt、userNameTxt 和 passwordTxt。
双击“按钮”控件以指定 Click 事件的代码。根据所用语言插入适当的代码。
[C#]
// 声明所需变量。
TableLogOnInfo logOnInfo = new TableLogOnInfo ();
int i = 0;

// 对报表中的每个表依次循环。
for (i=0;i == Report.Database.Tables.Count - 1;i++)
{
// 设置当前表的连接信息。
logOnInfo.ConnectionInfo.ServerName = serverNameTxt.Text;
logOnInfo.ConnectionInfo.DatabaseName = dbNameTxt.Text;
logOnInfo.ConnectionInfo.UserID = userNameTxt.Text;
logOnInfo.ConnectionInfo.Password = passwordTxt.Text;
Report.Database.Tables [i].ApplyLogOnInfo (logOnInfo);
}
注意 受密码保护的 Microsoft Access 和 Paradox 等 PC 数据库也使用该方法,但 LogOnInfo.ServerName 和 LogOnInfo.DatabaseName 要保留为空。
于是我仿照这个样子,尝试了一下,出错提示:没有发现TableLogOnInfo 和Report。
后来我发现TableLogOnInfo 是属于CrystalDecisions.Shared 命名空间的成员。于是我添加引用:
using CrystalDecisions.Shared ;
这次问题出现在Report。
Report并没有这个函数或类!
发现Report只是一个用户定义的对象,不是系统本身的对象。
在我困惑的时候,突然我想,为什么不看看Report后面的DataBase,这是个什么东西,终于问题解决了,在帮助里找到如下信息
ReportDocument oRpt = new ReportDocument();
Report属于DocumentCrystalDecisions.CrystalReports .Engine 类的成员。
修改代码:并添加引用
using CrystalDecisions.Shared ;//负责解释TableLogOnInfo类
using CrystalDecisions.CrystalReports .Engine ;//负责解释ReportDocument类private void Page_Load(object sender, System.EventArgs e)
{
TableLogOnInfo logOnInfo = new TableLogOnInfo ();
//这里必须事先申明一个ReportDocument对象 Report,同时加载数据报表
ReportDocument oRpt = new ReportDocument();
oRpt.Load("c:\\inetpub\\wwwroot\\exer\\pagelet\\crystal\\cr1.rpt");//修改为你自//己的正确位置

//建立安全信息
//受密码保护的 Microsoft Access 和 Paradox 等 PC 数据库也使用该方法,但 LogOnInfo.ServerName //和 LogOnInfo.DatabaseName 要保留为空
logOnInfo.ConnectionInfo.ServerName = "www";
logOnInfo.ConnectionInfo.DatabaseName = "archives";
logOnInfo.ConnectionInfo.UserID = "sa";
logOnInfo.ConnectionInfo.Password = "123456";

oRpt.Database .Tables [0].ApplyLogOnInfo (logOnInfo);

//建立.rpt文件与CryStalReportviewer文件之间的连接
CrystalReportViewer1.ReportSource = oRpt;
}
报表文件终于出现!
哇,我好高兴,禁不住站起来伸了个懒腰!

步骤四:最终的完整版的代码
上面的代码不具有系统可扩充和灵活性。缺点有二:
(1)、数据报表格式文件是采用绝对路径
(2)、数据库访问权限的设置一旦设定,在最终发布是无法修改的,特别是客户的SQL SERVER服务器不可能和你调试的程序环境是一样的
基于这个考虑。引进两个比较好的东西:
(1)、Server.Mappath函数
(2)、读取web.config(本示例同时告诉你如何操作web.config配置文件)
最终修改如下:(完整代码)数据库为sql server2000
using CrystalDecisions.Shared ;//负责解释TableLogOnInfo类
using CrystalDecisions.CrystalReports .Engine ;//负责解释ReportDocument类

private void Page_Load(object sender, System.EventArgs e)
{
TableLogOnInfo logOnInfo = new TableLogOnInfo ();
//这里必须事先申明一个ReportDocument对象 Report,同时加载数据报表
ReportDocument oRpt = new ReportDocument();
//获取.rpt文件真实路径
string path1,path2;
path1=Server.MapPath ("\\exer\\pagelet");
path2=path1+"\\crystal\\cr1.rpt";
//oRpt.Load("c:\\inetpub\\wwwroot\\exer\\pagelet\\crystal\\cr1.rpt");
oRpt.Load (path2);

//从web.config中获取logOnInfo参数信息
string a,b,c,d;
//获取ServerName
a=System.Configuration .ConfigurationSettings .AppSettings ["servername"];
//获取DatabaseName
b=System.Configuration .ConfigurationSettings .AppSettings ["database"];
//获取UserId
c=System.Configuration .ConfigurationSettings .AppSettings ["userid"];
//获取password
d=System.Configuration .ConfigurationSettings .AppSettings ["pass"];
//设置logOnInfo参数
logOnInfo.ConnectionInfo.ServerName = a;
logOnInfo.ConnectionInfo.DatabaseName = b;
logOnInfo.ConnectionInfo.UserID = c;
logOnInfo.ConnectionInfo.Password = d;

oRpt.Database .Tables [0].ApplyLogOnInfo (logOnInfo);

//建立.rpt文件与CryStalReportviewer文件之间的连接
CrystalReportViewer1.ReportSource = oRpt;
}


整个演示的操作过程说明:
1、 在解决方案资源管理器里,你需要存放报表文件处,添加新项:CrystalReport报表,起名为cr1.rpt
2、 在随后出现的“报表专家”中选择数据源时,请务必选择OLE DB,然后根据你的数据库的要求选择响应的驱动引擎:
SQL SERVER:Microsoft OLE DB Provider for SQL server
Access:Microsoft Jet.4.0
3、 输入正确的数据库连接,这一步大家一般的情况下不会出错!
4、 建立数据报表,并保存cr1.rpt文件
5、 打开webform1.aspx。添加crystalreportviewer控件:名称为:CrystalReportViewer1
6、 在webform1.aspx.cs中的page_load事件中添加上面的代码:
(注意:引用千万不要忘了!)


*****************************************************
下面是web.config中与本内容有关的细节
<appSettings>
<add key="servername" value="www"/>
<add key="database" value="archives"/>
<add key="userid" value="admin"/>
<add key="pass" value="123456"/>
</appSettings

polarlm 2004-03-30
  • 打赏
  • 举报
回复
水晶报表支持动态赋予数据,而不是数据源!!!
但是你的报表必须是给定格式的,而且数据源也是确定的,你可以自己建立一个XML格式的数据集作为你的数据源,在运行的时候给它赋值,但是如果你的dataSet是变化的,那就不好办了。基本上来说一个DataSet对应一张报表。
这也符合习惯
因为查询条件变化以后,也许你的报表的标题变了,一些文本变了,显示的字段变了……
如果你查询出来的是同一种东西,那么你可以给定数据集,然后根据你的查询结果,给里面的字段赋值,但是显示出来的报表也只能是一种格式的。
elite2018 2004-03-30
  • 打赏
  • 举报
回复
步骤一:看示例文件
水晶报表自带一个示例文件,数据库是access(不带密码的)。我首先运行示例文件(基于webform和winform)结果显示了正确的报表,正如“飞刀”的示例。
于是,建立了一个报表文件和.aspx文件,结果显示登陆失败!把报表文件换成示例的报表文件,不再出错。
问题出在什么地方?难道是报表格式文件有关于登陆权限的设置?通过跟踪、调试,报表文件和示例报表文件,没有发现任何的不同。看来问题不在报表文件。
是数据库的问题?我建立一个access结果还是登陆失败!
不是数据库的问题(我自己的数据库是未带密码的access,帮助中的数据库也是如此)?也不是报表格式文件的问题(我仔细分析了两者的原代码是相同的)?
那么问题出现在什么地方?我白思不得其解!
步骤二:找帮助文件

通过 Crystal Reports for Visual Studio .NET 访问安全数据库的过程在 Web 窗体和 Windows 窗体之间有所不同。在 Windows 窗体中,对话框自动提示用户输入用户名和密码(测试很容易成功)。而在 Web 窗体中,需要设计一个表单以从用户获取该信息。对于这两种情况,均可使用代码来指定用户名和密码,从而为应用程序的所有用户提供相同的安全等级。

对同样的数据库(先是用帮助示例中的access数据库,后来用自己建立的access数据库)。发现对于同一个报表文件,对于winform能显示成功,而对于webform则仍然显示登陆失败!
看来问题是出在权限的设置上。

步骤三:研究帮助,终于成功!
找到“设置数据库登录参数”字样,里面提供了一些后来发现是非常有用的信息:
下列示例说明如何将登录参数传递到报表的表中。该示例使用到某个安全的 SQL Server 数据库的连接。

启动一个新项目
向窗体添加一个“按钮”和四个“文本框”控件。
将“文本框”控件分别命名为:serverNameTxt、dbNameTxt、userNameTxt 和 passwordTxt。
双击“按钮”控件以指定 Click 事件的代码。根据所用语言插入适当的代码。
[C#]
// 声明所需变量。
TableLogOnInfo logOnInfo = new TableLogOnInfo ();
int i = 0;

// 对报表中的每个表依次循环。
for (i=0;i == Report.Database.Tables.Count - 1;i++)
{
// 设置当前表的连接信息。
logOnInfo.ConnectionInfo.ServerName = serverNameTxt.Text;
logOnInfo.ConnectionInfo.DatabaseName = dbNameTxt.Text;
logOnInfo.ConnectionInfo.UserID = userNameTxt.Text;
logOnInfo.ConnectionInfo.Password = passwordTxt.Text;
Report.Database.Tables [i].ApplyLogOnInfo (logOnInfo);
}
注意 受密码保护的 Microsoft Access 和 Paradox 等 PC 数据库也使用该方法,但 LogOnInfo.ServerName 和 LogOnInfo.DatabaseName 要保留为空。
于是我仿照这个样子,尝试了一下,出错提示:没有发现TableLogOnInfo 和Report。
后来我发现TableLogOnInfo 是属于CrystalDecisions.Shared 命名空间的成员。于是我添加引用:
using CrystalDecisions.Shared ;
这次问题出现在Report。
Report并没有这个函数或类!
发现Report只是一个用户定义的对象,不是系统本身的对象。
在我困惑的时候,突然我想,为什么不看看Report后面的DataBase,这是个什么东西,终于问题解决了,在帮助里找到如下信息
ReportDocument oRpt = new ReportDocument();
Report属于DocumentCrystalDecisions.CrystalReports .Engine 类的成员。
修改代码:并添加引用
using CrystalDecisions.Shared ;//负责解释TableLogOnInfo类
using CrystalDecisions.CrystalReports .Engine ;//负责解释ReportDocument类private void Page_Load(object sender, System.EventArgs e)
{
TableLogOnInfo logOnInfo = new TableLogOnInfo ();
//这里必须事先申明一个ReportDocument对象 Report,同时加载数据报表
ReportDocument oRpt = new ReportDocument();
oRpt.Load("c:\\inetpub\\wwwroot\\exer\\pagelet\\crystal\\cr1.rpt");//修改为你自//己的正确位置

//建立安全信息
//受密码保护的 Microsoft Access 和 Paradox 等 PC 数据库也使用该方法,但 LogOnInfo.ServerName //和 LogOnInfo.DatabaseName 要保留为空
logOnInfo.ConnectionInfo.ServerName = "www";
logOnInfo.ConnectionInfo.DatabaseName = "archives";
logOnInfo.ConnectionInfo.UserID = "sa";
logOnInfo.ConnectionInfo.Password = "123456";

oRpt.Database .Tables [0].ApplyLogOnInfo (logOnInfo);

//建立.rpt文件与CryStalReportviewer文件之间的连接
CrystalReportViewer1.ReportSource = oRpt;
}
报表文件终于出现!
哇,我好高兴,禁不住站起来伸了个懒腰!

步骤四:最终的完整版的代码
上面的代码不具有系统可扩充和灵活性。缺点有二:
(1)、数据报表格式文件是采用绝对路径
(2)、数据库访问权限的设置一旦设定,在最终发布是无法修改的,特别是客户的SQL SERVER服务器不可能和你调试的程序环境是一样的
基于这个考虑。引进两个比较好的东西:
(1)、Server.Mappath函数
(2)、读取web.config(本示例同时告诉你如何操作web.config配置文件)
最终修改如下:(完整代码)数据库为sql server2000
using CrystalDecisions.Shared ;//负责解释TableLogOnInfo类
using CrystalDecisions.CrystalReports .Engine ;//负责解释ReportDocument类

private void Page_Load(object sender, System.EventArgs e)
{
TableLogOnInfo logOnInfo = new TableLogOnInfo ();
//这里必须事先申明一个ReportDocument对象 Report,同时加载数据报表
ReportDocument oRpt = new ReportDocument();
//获取.rpt文件真实路径
string path1,path2;
path1=Server.MapPath ("\\exer\\pagelet");
path2=path1+"\\crystal\\cr1.rpt";
//oRpt.Load("c:\\inetpub\\wwwroot\\exer\\pagelet\\crystal\\cr1.rpt");
oRpt.Load (path2);

//从web.config中获取logOnInfo参数信息
string a,b,c,d;
//获取ServerName
a=System.Configuration .ConfigurationSettings .AppSettings ["servername"];
//获取DatabaseName
b=System.Configuration .ConfigurationSettings .AppSettings ["database"];
//获取UserId
c=System.Configuration .ConfigurationSettings .AppSettings ["userid"];
//获取password
d=System.Configuration .ConfigurationSettings .AppSettings ["pass"];
//设置logOnInfo参数
logOnInfo.ConnectionInfo.ServerName = a;
logOnInfo.ConnectionInfo.DatabaseName = b;
logOnInfo.ConnectionInfo.UserID = c;
logOnInfo.ConnectionInfo.Password = d;

oRpt.Database .Tables [0].ApplyLogOnInfo (logOnInfo);

//建立.rpt文件与CryStalReportviewer文件之间的连接
CrystalReportViewer1.ReportSource = oRpt;
}


整个演示的操作过程说明:
1、 在解决方案资源管理器里,你需要存放报表文件处,添加新项:CrystalReport报表,起名为cr1.rpt
2、 在随后出现的“报表专家”中选择数据源时,请务必选择OLE DB,然后根据你的数据库的要求选择响应的驱动引擎:
SQL SERVER:Microsoft OLE DB Provider for SQL server
Access:Microsoft Jet.4.0
3、 输入正确的数据库连接,这一步大家一般的情况下不会出错!
4、 建立数据报表,并保存cr1.rpt文件
5、 打开webform1.aspx。添加crystalreportviewer控件:名称为:CrystalReportViewer1
6、 在webform1.aspx.cs中的page_load事件中添加上面的代码:
(注意:引用千万不要忘了!)


*****************************************************
下面是web.config中与本内容有关的细节
<appSettings>
<add key="servername" value="www"/>
<add key="database" value="archives"/>
<add key="userid" value="admin"/>
<add key="pass" value="123456"/>
</appSettings
MarcuseXiao 2004-03-30
  • 打赏
  • 举报
回复
两个星的也有文不对题的,你那答的文不对题
honkerboy07 2004-03-29
  • 打赏
  • 举报
回复
to polarlm(今年本命年);
俺可没那么大本事,只是想把报表完全当作一个对象来操作,而且是这个对象的每个属性都要能操作。 作个设计器?? 我的想法其实是酱紫的: 在已做好的查询界面上,用户选择查询参数,点击查询按钮,剩下的就是程序后台运行的一些动作了:查询数据->生成数据集->将数据集绑定到reportdocument(?) ,设置好格式什么,然后就能得到用户满意的报表,不要再修改了,直接打印就可以提交查询结果的报表——对用户来说这是比较舒服的工作了,呵呵,可对于俺来讲,这可是头大n倍的事情啊~ ^_^ !
dotnba 2004-03-29
  • 打赏
  • 举报
回复
关注
polarlm 2004-03-29
  • 打赏
  • 举报
回复
建议到水晶报表的论坛看看
偶觉得你就是想做一个报表设计器

110,539

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧