我的数据库是局域网上的sql sever上的,有很多表,但是里面没有真实的数据,
但是我用它自带的pubs做也是这样啊,如果有空,帮忙看一下这个网页,我是按那上面做的http://www.yesky.com/20020618/1616443.shtml谢了

解决方案 »

  1.   

    转贴一个文章:
    启动一个新项目 
    向窗体添加一个“按钮”和四个“文本框”控件。 
    将“文本框”控件分别命名为: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只是一个用户定义的对象,不是系统本身的对象。
    在我困惑的时候,突然我想,为什么不看看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事件中添加上面的代码:
    (注意:引用千万不要忘了!)
      

  2.   

    private void Page_Load(object sender, System.EventArgs e)
    {
    //使用集成身份验证在页面中加入  ReportSource='<%   
    // # "C:\\Inetpub\\wwwroot\\WebApplication1\\CrystalReport1.rpt"%>'
    //使用混合认证加入

    ReportDocument Report = new ReportDocument();
    Report.Load(Server.MapPath("CrystalReport1.rpt"));
    TableLogOnInfo logOnInfo = new TableLogOnInfo(); //对报表中的每个表进行循环
    for(int i=0;i<=Report.Database.Tables.Count-1;i++)
    {
    logOnInfo.ConnectionInfo.UserID = "sa";
    logOnInfo.ConnectionInfo.Password = "SqlSql";
    Report.Database.Tables[i].ApplyLogOnInfo(logOnInfo);
    }
    CrystalReportViewer1.ReportSource = Report;
    CrystalReportViewer1.BestFitPage = true;
    CrystalReportViewer1.DataBind();         
    Page.DataBind();
    }
    在数据库中加入用户名:
    企业管理器--->(数据库服务器)---->(数据库)---->用户----->新建数据库用户
      -->在登录名中选择新建--->在"常规""名称"中点击后面的按钮---->选择"ASPNET"用户
    经过以上设置应该可以运行了.
      

  3.   

    你的数据库设置有问题,我就没问题,你用ACCESS看看
      

  4.   

    你是这样做的啊,但做水晶报表的时候,我一般习惯使用一个DataSet绑定到水晶报表,然后在将从数据库中的数据填充到自己的数据集中。我不知道这样是否好,反正我感觉比较顺手。如果对此感兴趣,不妨借鉴。