QTP如何连接/查询数据库

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介:       在日常测试工作中经常会遇到有关于数据的测试,比如数据的正确性,完整性,测试人员造的测试数据预期与实际程序运行结果是否一致,如果这个时候数据量比较多的情况下,通过人工比对无疑是一项非常耗时,而且安全系数不高的工作,今天分享一篇通过自动化测试工具QTP怎么连接和查询数据库,解决数据库无法连接等问题,轻松完成所需要的工作,工作效率和正确性将得到保证。
  1.  

     

      在日常测试工作中经常会遇到有关于数据的测试,比如数据的正确性,完整性,测试人员造的测试数据预期与实际程序运行结果是否一致,如果这个时候数据量比较多的情况下,通过人工比对无疑是一项非常耗时,而且安全系数不高的工作,今天分享一篇通过自动化测试工具QTP怎么连接和查询数据库,解决数据库无法连接等问题,轻松完成所需要的工作,工作效率和正确性将得到保证。

    工具/原料

    • QTP测试软件

    • windows系统配置mysql数据源

       

       

    1、定义一个变量名为Conn的变量,通过set方法创建一个数据库实例

    Dim Conn

    Set Conn=CreateObject("ADODB.Connection")        '创建数据库实例

     

  2. 2

    通过mysql ODBC5.1 Driver数据源连接Mysql数据库,并配置mysql数据库的通行证

    Const ConnectionString="Driver={Mysql ODBC 5.1 Driver};DATABASE=datebase_name;PWD=password;PORT=3306;SERVER=192.178.***。** ;UID=user_name"

  3. 3

    校验数据库是否已经成功连接,Reporter.ReportEvent micPass,"testing",这条语句的结果是最后显示在运行后结果的,平时在调试的时候可以使用 msgbox "连接数据库成功",就是弹出一个框,打印引号中的字。

    Conn.Open ConnectionString    '打开数据库

    If Conn.State<>0Then

    Reporter.ReportEvent micPass,"testing","连接数据库成功"         '校验数据库是否成功连接

    msgbox "连接数据库成功"

    else

    Reporter.ReportEvent micFail,"testing","连接数据库失败"

    End If

     

  4. 4

    Set str=CreateObject("ADODB.Recordset")'使用set方法创建数据集实例

  5. 5

    通过sql语句查出需要的数据,然后通过for循环,循环读取数据库中的内容,并将所需要的数据打印出来。

    '查询数据库

    sql="SELECT shop_id FROM taobao_shop" '这条语句是对数据库的查询命令,这条语句是查询一个表名为taobao_shop的数据,但是只显示shop_id字段

    str.Open sql,conn,1,1'1,1表示只读;1,3表示插入数据;2,3表示修改数据

    str.MoveFirst'使游标指向第一个记录

    sum=""

     While Not str.EOF

     

      msgbox str.Fields("shop_id")  '测试数据库中某一个字段的数据获取是否正确

      For i=0to str.Fields.Count-1'str.Fields.Count表示字段个数

         sum=sum & str(i) &""'把整个记录显示出来

      Next

         Print sum & vbCRLF'打印所有查询的记录

         sum=""  '清零

         str.MoveNext'使游标进入下一个,这里其实就是一个循环,循环去读取SQL语句查询到的数据,然后打印出来。

    Wend

     

  6. 6

    在完成脚本查询以后不要忘记关闭和释放数据库和实例集。

    str.Close '关闭数据集实例

    Set str=Nothing '释放数据集

    Conn.Close '关闭数据库实例

    Set Conn=Nothing '释放数据库连接

     

  7. 7

    完整的连接脚本代码:

    Dim Conn

    Set Conn=CreateObject("ADODB.Connection")                             '创建数据库实例

    'Const ConnectionString="Driver={Mysql ODBC 5.1 Driver};DATABASE=test;PWD=root;PORT=3306;SERVER=localhost;UID=root"              '配置数据库通行证

    Const ConnectionString="Driver={Mysql ODBC 5.1 Driver};DATABASE=datebase_name;PWD=password;PORT=3306;SERVER=192.178.***。** ;UID=user_name"

    Conn.Open ConnectionString

    If Conn.State<>0Then

    Reporter.ReportEvent micPass,"testing","连接数据库成功"         '校验数据库是否成功连接

    msgbox "连接数据库成功"

    else

    Reporter.ReportEvent micFail,"testing","连接数据库失败"

    End If

    Set str=CreateObject("ADODB.Recordset")'创建数据集实例

    '查询数据库

    sql="SELECT shop_id FROM taobao_shop"

    str.Open sql,conn,1,1'1,1表示只读;1,3表示插入数据;2,3表示修改数据

    str.MoveFirst'使游标指向第一个记录

    sum=""

     While Not str.EOF

     

      msgbox str.Fields("shop_id")  '测试查询得到的数据

      For i=0to str.Fields.Count-1'str.Fields.Count表示字段个数

         sum=sum & str(i) &""'把整个记录显示出来

      Next

         Print sum & vbCRLF'打印所有查询的记录

         sum=""  '清零

         str.MoveNext'使游标进入下一个

    Wend

     

    str.Close '关闭数据集实例

    Set str=Nothing

    Conn.Close '关闭数据库实例

    Set Conn=Nothing

     

     

     

技术改变世界! --狂诗绝剑
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1天前
|
关系型数据库 MySQL 数据库
mysql 设置环境变量与未设置环境变量连接数据库的区别
设置与未设置MySQL环境变量在连接数据库时主要区别在于命令输入方式和系统便捷性。设置环境变量后,可直接使用`mysql -u 用户名 -p`命令连接,而无需指定完整路径,提升便利性和灵活性。未设置时,需输入完整路径如`C:\Program Files\MySQL\...`,操作繁琐且易错。为提高效率和减少错误,推荐安装后设置环境变量。[查看视频讲解](https://www.bilibili.com/video/BV1vH4y137HC/)。
17 3
mysql 设置环境变量与未设置环境变量连接数据库的区别
|
3天前
|
Oracle Java 关系型数据库
【服务器】python通过JDBC连接到位于Linux远程服务器上的Oracle数据库
【服务器】python通过JDBC连接到位于Linux远程服务器上的Oracle数据库
14 6
|
3天前
|
SQL Java 关系型数据库
【JAVA基础篇教学】第十六篇:Java连接和操作MySQL数据库
【JAVA基础篇教学】第十六篇:Java连接和操作MySQL数据库
|
4天前
|
SQL 关系型数据库 MySQL
MySQL数据库的约束+进阶版新增与查询-2
MySQL数据库的约束+进阶版新增与查询
12 1
|
4天前
|
关系型数据库 MySQL 测试技术
MySQL数据库的约束+进阶版新增与查询-1
MySQL数据库的约束+进阶版新增与查询
15 1
|
5天前
|
SQL Java 数据库连接
Java数据库编程实践:连接与操作数据库
Java数据库编程实践:连接与操作数据库
9 0
|
6天前
|
关系型数据库 Java 数据库
docker部署postgresql数据库和整合springboot连接数据源
docker部署postgresql数据库和整合springboot连接数据源
16 0
|
7天前
|
SQL 数据库
SQL数据库基础语法-查询语句
SQL数据库基础语法-查询语句
|
7天前
|
SQL JSON 关系型数据库
[UE虚幻引擎插件DTPostgreSQL] PostgreSQL Connector 使用蓝图连接操作 PostgreSQL 数据库说明
本插件主要是支持在UE蓝图中连接和操作PostgreSQL 数据库。
16 2
|
3天前
|
关系型数据库 MySQL 数据库
docker MySQL删除数据库时的错误(errno: 39)
docker MySQL删除数据库时的错误(errno: 39)
10 0