我用水晶报表中的ADO数据库连接方式连sql server数据库,为什么一显示报表前弹出对话框
让输入密码,怎么才能让它记住秘密哪?谢谢答复!

解决方案 »

  1.   

    连接字符串的格式应为:
    Provider = SQLOLEDB.1;Password = ; Persist Security Info = True;User ID = sa;Initial Catalog = DRUGDB; Data Source = 192.168.30.122(或机器名)
    注意密码的设置。
      

  2.   

    你最好把查询结果输出到本地的ACCESS中  再用报表系统调用  本地的ACCESS中的数据 ,那样就稳定多了  速度影响不大的
      

  3.   

    大哥们啊,我一定要连sql server啊
    access,我早就做出来了
    但水晶报表里的确没有“允许保存密码”这项啊。
      

  4.   

    恩恩,好像是这样的,我当然用C#,本来打算用ado连的,试了好久不行,才改用dataset绕过去的
      

  5.   

    试试在SQL的企业管理器中将SQL的认证方式改为windows与sql混合认证
      

  6.   

    先使用ADODC控件,生成连接字符串,在这个过程中有保存密码的选项的
      

  7.   

    Report.Database.LogOnServer ("odbc", "serverName", , "ID", "PWD") 这个方法,可以设置连接信息
      

  8.   

    我连的是sql server,应该怎么写啊Report.Database.LogOnServer ("odbc", "serverName", , "ID", "PWD") 这个方法,可以设置连接信息这种方法到底能不能实现哪?
      

  9.   

    Report.Database.LogOnServer ("odbc", "serverName", , "ID", "PWD")
    这个方法根本不行呀,提示不支持
      

  10.   

    报表设计阶段不要保存有环境依赖的信息
    另外,上面说的LogOnServer方法是正确的,如果说不支持,请先检查你的cr版本
      

  11.   

    动态连接数据库就行了
        conn.Open connstr
        SQL = "SELECT * From LSTable"
        rs.Open SQL, conn, adOpenKeyset, adLockPessimistic
        Set Report = CryApp.OpenReport(App.Path & "\test.rpt")
        Report.Database.SetDataSource rs
        Me.CRViewer91.ReportSource = Report
        Me.CRViewer91.ViewReport
      

  12.   

    我今天也遇到这个问题了,解决办法喊简单哦,就在连接字符串里手工在加入passward=密码就行了
      

  13.   

    才写过一篇文章,参考吧:http://blog.csdn.net/jhzyz/archive/2005/04/29/367442.aspx在VB中使用水晶报表的一种简易编程方法 
    Chinabyte链接:http://soft.yesky.com/SoftChannel/72342371928637440/20050413/1935383.shtml或:http://dev.yesky.com/SoftChannel/72342371928637440/20050413/1935383.shtml      水晶报表(Crystal Report)的业内最专业、功能最强的报表系统,它除了强大的报表功能外,最大的优势是实现了与绝大多数流行开发工具的集成和接口。在VS.Net平台做过报表开发的程序员,一定都对水晶报表强大、高效、集成等特性留下了深刻印象。除了开发新程序外,在工作中我们常需要接触到很多较早的软件系统报表功能升级的需求,如果能结合水晶报表这一强大的工具,往往能事半功倍。      VB是以前流行的数据库开发平台,用其开发的C/S系统在社会上有非常大的保有量,但VB超弱的报表功能往往让程序员面对客户的升级要求一筹莫展。本文并不做水晶报表的使用和编程教学,实际上水晶报表本身的使用方法和VS.Net平台并没有太大的差别,我主要是和大家探讨一下VB和水晶报表的一种较方便的接口方式。我的开发测试平台是Windows2003 Standard简体中文版、VB6.0+sp5英文版、Crystal 9.0简体中文开发版。      关于在水晶报表中制作报表模板的方法,并非本文的探讨范围,读者可以参考Crystal Report的帮助文件和官方网站的技术资料。简单地说,首先要通过水晶报表的数据库引擎手动连接相应的表结构,制作报表模板,并保存为rpt文件,该项操作和利用VB自带的报表工具制作报表大同小异。      用VB调用水晶报表进行报表开发的简单接口方法就是,在水晶报表中用"仅字段定义"来获得字段分布文件,用虚拟的文件创建表字段,用CRAXDRT对象来强制改变数据源(ADO.recordset),其效果相当于在VB中调用了rpt文件。下面分步骤介绍编程方法。 第一步:
    在VB工程中Project菜单加入"Add Crystal Report 9",报表名使用默认即可。这时Form2(Crystal Rerport自动添加的Form,假设名为Form2)被自动分配了如下代码:Option Explicit
    dim Report as New Cystal1Private Sub Form_Load()Screen.MousePointer = vbHourglass     '调用水晶报表时置鼠标为沙漏状CRViewer91.ReportSource = Report     '该语句的赋值将在后面被修改CRViewer91.ViewReport
    Screen.MousePointer = vbDefault       '调用水晶报表完成后置鼠标为默认形状End SubPrivate Sub Form_Resize()CRViewer91.Top = 0
    CRViewer91.Left = 0
    CRViewer91.Height = ScaleHeight
    CRViewer91.Width = ScaleWidthEnd Sub第二步:
    点击Crystal Report设计器的"数据库字段",选定"数据库专家...",然后点"创建新连接",再点"仅字段定义",创建"数据库定义"文件,字段名和宽度和原数据库表保持一致。最后,在数据库字段中获得了相应字段,将其置于报表上,按水晶报表的要求配置。第三步:
    该步骤非常关键,添加一个Modual到工程文件中,定义全局的ADODB变量,实现数据库和水晶报表的动态连接。代码如下:Public conn As New ADODB.Connection
    Public rs As New ADODB.Recordset第四步:
    关于VB程序的ADO数据库连接注意事项,请看下面的打印按钮例程。Private Sub Command1_Click()    Dim connstr As String    If conn.State = adStateOpen Then conn.Close
        
        connstr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & App.Path & "\prtest.mdb;Persist Security Info=False"    'prtest.mdb是程序当前目录的测试Access数据库
        
        conn.ConnectionString = connstr
        
        conn.Open 
        
        conn.CursorLocation = adUseClient 
        
        If rs.State = adStateOpen Then rs.Close
        
        rs.Open "test", conn, adOpenKeyset, adLockReadOnly
        
    '    Report.Database.SetDataSource rs, 3, 1  '此行取消
            Form2.Show 1   '数据库连接完成后,调用Form2水晶报表工程
        
        
    End Sub需要提请大家注意的是,上面代码中的Report.Database.SetDataSource rs, 3, 1是初用水晶报表的程序员容易犯的错误,使用该语句后将造成数据库和水晶报表的连接失败。如何动态调用水晶报表呢?请看第五步。第五步:
    创建水晶报表和数据库数据源的连接,需要修改上面Form2的代码。Option Explicit
    'dim Report as New Cystal1
    '上面一行取消Private Sub Form_Load()Dim oApp As New CRAXDRT.Application
    Dim oRpt As CRAXDRT.Report
    Dim reportName As String
    '上面三行是新增加的Screen.MousePointer = vbHourglass
    reportName = "\rpt\Pr1.rpt"      '定义要引用的rpt文件Set oRpt = oApp.OpenReport(App.Path & reportName, 1)oRpt.Database.SetDataSource rs    '连接水晶报表和数据源
    oRpt.ReadRecordsCRViewer91.ReportSource = oRpt  '启用水晶报表的预览功能CRViewer91.ViewReport
    Screen.MousePointer = vbDefault
    End SubPrivate Sub Form_Resize()CRViewer91.Top = 0
    CRViewer91.Left = 0
    CRViewer91.Height = ScaleHeight
    CRViewer91.Width = ScaleWidthEnd SubPrivate Sub Form_Unload(Cancel As Integer)
        
        'Set Report = Nothing
        
        Set rs = Nothing
        
        Set conn = Nothing
        
        Unload Form2
        
    End Sub      上面介绍了在VB中使用水晶报表进行报表开发的一种方法,该方法简单易用,适合初学者上手。大家熟悉以后,还可以继续学习Crystal Report提供的API函数(Lib库 Crpe32.dll)进行水晶报表开发,可以获得更大的灵活性。(完)源码下载:http://dl6.mydown.com/code/more/20050409_Crystal_VB6.rar
      

  14.   

    Private Sub Command1_Click()
       Dim a As Object
       Dim b As Report
       Set a = CreateObject("crystal.crpe.application")
       Set b = a.OpenReport("E:\Test\¤H¨Æ\­û¤u°ò¥»¸ê®Æ¤@Äýªí\Clint\CUPA_P102.rpt")
       b.Database.Tables(1).SetLogOnInfo "reportserver", "tempdb", "iemis", "ooooo"
       b.Database.Tables(1).Location = "tempdb.iemis.tmp_jesse_view_ch_p102"
       b.Preview
    End Sub