设置数据库登录参数

在帮助里我找到“设置数据库登录参数”字样,里面提供了一些后来发现是非常有用的信息:
下列示例说明如何将登录参数传递到报表的表中。该示例使用到某个安全的   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事件中添加上面的代码:
(注意:引用千万不要忘了!)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值