51Testing软件测试论坛

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

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 3046|回复: 5
打印 上一主题 下一主题

[原创] QTP连接数据库小技巧

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2010-7-26 17:24:39 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
QTP连接数据库是一个比较重要步骤可以检查系统插入、删除、修改的数据有无在数据库中更新,对于一些动态生成的元素,也可通过查找数据库来取得,比如:有些id号是递增产生的,也可通过查找数据库中该字段的最大值来取值。

作为一个新手,在使用QTP的过程中遇到很多问题,通过上网搜寻资料,这里做了一下小结,知道的人就可以不看了,希望对不了解的人有所帮助。

这里主要以我工作的用到的DB2数据库为例,先要在本地安装DB2的客户端,建立数据链接;接下来就是:
先建立一个xx.udl的文件,打开后,编辑连接,测试连接,然后用记事本打开,检查有语句如:

###############################################################################
[oledb]
; Everything after this line is an OLE DB initstring(此行下都是OLE DB的初始化语句)
Provider=MSDASQL.1 Password=db2 Persist Security Info=True;User ID=db2admin; Data Source=LOANCS
###############################################################################
也就是说“Provider=MSDASQL.1 Password=db2 Persist Security Info=True;User ID=db2admin;Data Source=LOANCS”就是数据库连接语句了,也就是我们需要的ConnectionString了。
例子如下:


Dim conn,res,strSql'定义变量
Set conn = CreateObject("ADODB.Connection")'创建连接
conn.ConnectionString ="Provider=MSDASQL.1 Password=db2 Persist Security Info=True;User ID=db2admin;Data Source=LOANCS"
conn.Open'开启连接

If conn.State = 0 Then

Reporter.ReportEvent micFail,"测试连接","数据库连接失败!"

conn.Close

Set conn = Nothing
Else
      Reporter.ReportEvent micPass,"测试连接","数据库连接成功!"
End If
Set res = CreateObject("ADODB.RecordSet")'创建一个记录集对象
strSql="select * from loan.xt_czydl" '查询语句
res.Open strSql,conn
res.MoveFirst
Do

Reporter.ReportEvent micDone,"数据为:",cstr(res(0))+"
"+cstr(res(1)) '取得数据结果表前两列

res.MoveNext
loop until res.EOF = TRUE
res.Close
Set res = Nothing
conn.Close
Set conn = Nothing

[ 本帖最后由 mao303mao 于 2010-7-27 19:35 编辑 ]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing

x
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

该用户从未签到

2#
发表于 2010-7-27 08:25:44 | 只看该作者
谢谢楼主。挺有用的
回复 支持 反对

使用道具 举报

该用户从未签到

3#
发表于 2010-7-27 10:29:45 | 只看该作者
那个~~连接成功和失败的测试为什么不放在一个IF里。。。。。
回复 支持 反对

使用道具 举报

该用户从未签到

4#
 楼主| 发表于 2010-7-27 19:13:26 | 只看该作者

是疏忽了。。。其实效果一样,改一下:
If conn.State = 0 Then

Reporter.ReportEvent micFail,"
测试连接","数据库连接失败!"

conn.Close


Set conn = Nothing

Else
       Reporter.ReportEvent micPass,"测试连接","数据库连接成功!"
End If

再加上udl文件的截图:
回复 支持 反对

使用道具 举报

该用户从未签到

5#
发表于 2010-7-30 19:54:45 | 只看该作者
楼主 为什么我运行到 res.Open strSql,conn 这里 提示 数据类型不被支持
回复 支持 反对

使用道具 举报

该用户从未签到

6#
 楼主| 发表于 2010-8-2 20:06:44 | 只看该作者
你能告诉我,提示信息吗;
你可以检查一下sql语句,还有,注意,结果集中数据的个数。

[ 本帖最后由 mao303mao 于 2010-8-2 20:27 编辑 ]
回复 支持 反对

使用道具 举报

本版积分规则

关闭

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

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

GMT+8, 2024-11-6 05:02 , Processed in 0.072845 second(s), 28 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

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