51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 3417|回复: 7
打印 上一主题 下一主题

[Robot] 如何不通过DSN访问数据库

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2005-10-13 11:55:47 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Robot里的SQLOpen必须指定DSN才能访问数据库,现在我需要通过指定Server地址、用户名、密码直接访问数据库,请问应该怎么做?谢谢了!
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

该用户从未签到

2#
发表于 2005-10-13 17:18:04 | 只看该作者
SQLOpen (connectStr$[,outputStr$][,prompt%])

Comments
The content of connectStr is described in the Microsoft Programmer’s Reference
Guide for ODBC. An example string might be "DSN=datasourcename;
UID=myid; PWD=mypassword". The return must be a Long.


并非必须指定DSN才能访问数据库,连接字符串符合“Microsoft Programmer’s Reference Guide for ODBC”就可以,可以直接在字符串中指定Server地址、用户名、密码访问数据库。你试一下
回复 支持 反对

使用道具 举报

该用户从未签到

3#
 楼主| 发表于 2005-10-13 23:36:45 | 只看该作者
ok!谢谢!
回复 支持 反对

使用道具 举报

该用户从未签到

4#
发表于 2005-11-4 18:09:22 | 只看该作者

re:sstars

你是如何做的,能写个出来共享一下吗。做个参考
回复 支持 反对

使用道具 举报

该用户从未签到

5#
发表于 2005-11-5 19:20:39 | 只看该作者

也可以通过ADO来操作……

' BTW,自己多看看书,每个人的时间都是有限的
' connection and recordset variables
Dim Cnxn As Object
Dim rsCustomers As Object
Dim strCnxn, strSQLCustomers As String

' open connection
Set Cnxn = CreateObject("ADODB.Connection")
strCnxn = "rovider=sqloledb;Data Source=MyServer;" & _
    "Initial Catalog=northwind;User Id=saassword=; "
Cnxn.Open strCnxn

' create and open Recordset using recordset - open
Set rsCustomers = CreateObject("ADODB.Recordset")
strSQLCustomers = "SELECT CompanyName, ContactName, City " & _
    "FROM Customers"
rsCustomers.Open strSQLCustomers, Cnxn
rsCustomers.CursorLocation = 3

' Display ADO Data from Customer Table
Do Until rsCustomers.EOF
    SQAConsoleWrite rsCustomers("CompanyName")
    SQAConsoleWrite rsCustomers("ContactName")
    SQAConsoleWrite rsCustomers("City")

    rsCustomers.MoveNext
Loop
   
' clean up
rsCustomers.Close
Cnxn.Close
Set rsCustomers = Nothing
Set Cnxn = Nothing
回复 支持 反对

使用道具 举报

  • TA的每日心情
    无聊
    2015-6-14 21:08
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    6#
    发表于 2006-2-7 17:42:24 | 只看该作者

    提个问题?谢谢回答

    原帖由 dotaddress 于 2005-11-5 19:20 发表
    ' BTW,自己多看看书,每个人的时间都是有限的:)
    ' connection and recordset variables
    Dim Cnxn As Object
    Dim rsCustomers As Object
    Dim strCnxn, strSQLCustomers As String

    ' open connection
    Set ...


    感谢楼上的提供的代码,我找了一天终于找到了,非常感谢。我也照着样子试验了一下。提几个问题:
    1、“rsCustomers.CursorLocation = 3”这句语句有什么用呢?
    2、为什么我把这句话注释了就可以通过,不注释的话系统报错:“Runtime error '440' - Module SQL Server, Line 20. ADODB.Recordset: 对象打开时,不允许操作。”
    注:我的操作系统是windows 2000 + SP4,Robot 是 2003版的。我只修改了这两个变量:strCnxn、strSQLCustomers。
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    7#
    发表于 2006-2-9 21:30:10 | 只看该作者
    rsCustomers.CursorLocation = 3是使用客户端游标的意思,可能你的strSQLCustomers不是select吧,你可以找ado方面的资料看看
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    8#
    发表于 2006-2-27 12:53:06 | 只看该作者
    我的也提示了

    这个同客户端游标和服务器端游标没什么关系把

    在连接对象打开时,好像就是不能设置的cursorlocation属性
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-8 23:36 , Processed in 0.074481 second(s), 27 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表