1. 获取数据库连接串

    在本地新建一个.txt文件,修改扩展名名*.udl;双击*.udl文件,打开数据库链接属性,定位到"提供程序"选显卡,选中如sqlserver的连接  Microsoft  for OLE DB Provider for sql server,点击下一步;输入数据源,数据库用户名以及密码,选择数据库,点击测试连接,测试成功后,点击"确定"。如图所示

    然后用UE或记事本打开*.udl文件,sqlserver的连接串已经生成了,如下:

Provider=SQLOLEDB.;Password=trsadmin;Persist Security Info=True;User ID=sa;Initial Catalog=test;Data Source=.***.***.***

  2.连接数据库

Dim objConnection 'Connection对象实例
Dim strConnString '连接字符串
strConnString="Provider=SQLOLEDB.1;Password=trsadmin;Persist Security Info=True;User ID=sa;Initial Catalog=test;Data Source=192.***.***.***" Set objConnection = CreateObject("ADODB.CONNECTION") '建立Connection对象的实例
objConnection.Open strConnString '用Open方法建立与数据库连接
objConnection.state=0 '表示数据库连接失败

  3.关闭数据库连接

    objRecordSet.Close
objConnection.Close
Set objRecordSet = Nothing
Set objConnection = Nothing

  4.执行查询

Dim objRecordSet 'RecordSet对象实例
Dim sqlStr 'sql查询语句 Set objRecordSet = CreateObject("ADODB.Recordset") '建立Recordset对象的实例
objRecordSet.Open sqlStr,objConnection '执行查询 If (objRecordSet.BOF or objRecordSet.EOF) Then '查询不存在任何记录
executeSQL = NULL '返回NULL
Else '存在查询记录
'使用 GetRows 方法将记录从 Recordset 复制到二维数组中。第一个下标标识字段,第二个则标识记录号。
executeSQL = objRecordSet.GetRows() '返回查询结果的二维数组
End If

以下代码将数据库各个常用功能封装成函数,已测试通过,仅供参考:

Option Explicit
'公共对象
Dim objConnection 'Connection对象实例
Dim strConnString '连接字符串
Dim objRecordSet 'RecordSet对象实例 '==================================================================
' 函数功能:连接到数据库
' 参数说明:
' 1.strDBType(数据库类型:支持SQL SERVER、ORACEL、MYSQL、DB2、SYBASE)
' 2.strDBName(数据库名)
' 3.strUID(用户名)
' 4.strPWD(密码)
' 5.strIP(服务器名或IP地址)
' 返回结果:无
' 调用方法:ConnectDB(strDBType, strDBName, strUID, strPWD)
'==================================================================
Sub connectDB(strDBType, strDBName, strUID, strPWD,strIP)
Select Case UCase(Trim(strDBType)) '不同的数据库类型连接数据库的字符串不同
Case "SQL SERVER"
strConnString="Provider=SQLOLEDB; Data Source="& strIP &"; Initial Catalog="& strDBName &"; User ID="& strUID &"; Password="&strPWD
Case "ORACLE"
strConnString="Provider=OraOLEDB.Oracle; Data Source="& strDBName &"; User ID="& strUID &"; Password="& strPWD
Case "MYSQL"
strConnString="Driver={MySQL ODBC 5.1 Driver}; Server="& strIP &"; Database="& strDBName &"; User="&strUID&"; Password="& strPWD
   Case Else
Reporter.ReportEvent micFail,"数据库类型错误" ,"目前支持的数据库类型有:SQL SERVER、ORACEL、MYSQL、DB2、SYBASE"
End Select
Set objConnection = CreateObject("ADODB.CONNECTION") '建立Connection对象的实例
objConnection.Open strConnString '用Open方法建立与数据库连接
End Sub '==================================================================
' 函数功能:关闭数据库连接
' 参数说明:无
' 返回结果:无
' 调用方法:closeDB()
'==================================================================
Sub closeDB()
objRecordSet.Close
objConnection.Close
Set objRecordSet = Nothing
Set objConnection = Nothing
End Sub '==================================================================
' 函数功能:执行SQL语句
' 参数说明:sqlStr(SQL语句 )
' 返回结果:返回一个存放查询结果的二维数组
' 调用方法:results = executeSQL(sqlStr)
'==================================================================
Function executeSQL (sqlStr)
Call connectDB(gDBType,gDBName,gUID,gPWD,gIP)' 连接到数据库,函数的实参在配置文件中定义
Set objRecordSet = CreateObject("ADODB.Recordset") '建立Recordset对象的实例
objRecordSet.Open sqlStr,objConnection
If (objRecordSet.BOF or objRecordSet.EOF) Then '查询不存在任何记录
Reporter.ReportEvent micDone,"查询不存在任何记录","数据库中查询不存在任何记录!"
executeSQL = NULL '返回NULL
Else '存在查询记录
'使用 GetRows 方法将记录从 Recordset 复制到二维数组中。第一个下标标识字段,第二个则标识记录号。
executeSQL = objRecordSet.GetRows() '返回查询结果的二维数组
End If
Call closeDB() '关闭数据库连接
End Function

=======================================================================================================

 SQL执行结果处理:

======================================================================================================

1.检查查询结果记录数

Dim num,sql
sql = "select COUNT(ID) from TableName where .....
results = executeSQL(sql)
num=cint(results(,)) 'cint函数将查询结果转化为Integer类型,num=0表示查询结果为空,num=1表示查询结果有且唯一,num>1表示查询结果有多条

以下为使用案例:

'检查用户是否存在,如果存在则返回true,不存在则返回false
'参数为用户名
Function chkUserExistDB(userName)
Dim sql,results
sql = "select COUNT(USERNAME) from WCMUSER where USERNAME ='"& userName &"'"
results = executeSQL(sql)
If cint(results(,))= Then '存在用户userName
chkUserExistDB = true
Reporter.ReportEvent micDone, "用户存在","系统中存在用户["& userName &"] "
Else '不存在用户userName
chkUserExistDB = false
Reporter.ReportEvent micDone, "用户不存在","系统中不存在用户["& userName &"] "
End If
End Function

【QTP专题】连接数据库的更多相关文章

  1. 【QTP专题】05_参数化之Excel

    QTP使用外部Excel实现参数化主要有以下两种方式 导入到DataTable中 Syntax:DataTable.ImportSheet(FileName, SheetSource, SheetDe ...

  2. 【QTP专题-优化】VBS脚本启动QTP并运行测试

    使用vbs脚本启动QTP并运行测试,startQTP.vbs '******************************************************************** ...

  3. 【QTP专题】04_对象及操作方法

    本节介绍知识点包括 1.QTP自动化的原理 2.两类对象:TO(测试对象).RO(运行对象) 3.操作方法:SetTOProperty,GetROProperty,GetTOProperty 1.QT ...

  4. 【QTP专题】03_Add-in Manager插件

    1.什么是Add-in Manager Add-in Manager,故名思议这是一个QTP插件管理器,每次启动前需要选择对应的插件才能进行测试. 打开QTP之后,我们可以看到有如下的一个Add-in ...

  5. 【QTP专题】02_时间同步点问题

    一.什么是同步点 同步点是指在一个测试过程中,指示QuickTest等待应用程序中某个特定过程运行完成以后再运行下一步操作.Waits until the specified object prope ...

  6. 【QTP专题】01_安装时报DLL无法注册(转载)

    安装QTP过程中报很多DLL注册失败,全部忽略后安装完成,结果打开QTP录制的脚本无法保存,(点击保存按钮没反应) 1.问题分析: 问题a 使用精减版的操作系统 问题b  需要IE 6.0 及以上版本 ...

  7. QTP连接数据库

    '注意:其中DSN=数据源名:UID=用户名:PWD=用户密码 Dim Conn Set Conn=CreateObject("ADODB.Connection") Const C ...

  8. QTP安装连接Oracle数据库

    之前学过一段时间QTP,之后便没用这个笨重的东东,为了以防忘记,再次记录下曾经连接数据库经历了几天才搞好的事情(虽然这个工具可能已经过时,但是国企一般都会使用的) 前提条件: 你已经安装好了QTP / ...

  9. 我常用的VBS方法(QTP)

    这些是4年前在HP用QTP做自动化测试时候总结的一些,现在贴出来,说不准以后会不会用到 当初花了2天时间写的一个自动生成的Excel Report Public Function Report (st ...

随机推荐

  1. C# XML文件读取

    using System.Collections; using System.Collections.Generic; using System.IO; using System.Text; usin ...

  2. VS2017 Intelligense C++ 设置的几个重点

    1,高级-点到箭头的转换,用于指针操作 2,高级-成员列表筛选模式-一定要选[模糊],而不要选[智能] 这样在我们输入 vkphdfea就能检索到vkPhysicalDeviceFeatures, 而 ...

  3. js中格式化时间

    //时间格式化 Date.prototype.Format = function (fmt) { var o = { "M+": this.getMonth() + 1, &quo ...

  4. Mysql合并两列数据

    实例: UPDATE x_yiyuanpinggu_nengli SET ch_yuzhongfangxiang = CONCAT(ch_yuanyuzhong,ch_mubiaoyuzhong) M ...

  5. python+Django创建第一个项目

    1.首先搭建好环境 1.1 安装pyhton,Linux系统中,python是系统自带的所以就不用安装 1.2 安装Django框架 使用pip安装: pip install django 1.3 检 ...

  6. Django框架开发web网站的网页优化—页面静态化

    网站优化-页面静态化 1)概念 提前将页面所用到的数据从数据库查询出来,然后生成一个静态页面,之后用户来访问的时候,直接返回静态页面. 举例:首页静态化:获取首页用到的数据表中的数据,生成静态首页in ...

  7. SpringBoot01 InteliJ IDEA安装、Maven配置、创建SpringBoot项目、yml属性配置、多环境配置、自定义properties配置

    1 IntelliJ IDEA 安装 下载地址:点击前往 注意:需要下载专业版本的,注册码在网上随便搜一个就行啦 2 MAVEN工具的安装 2.1 获取安装包 下载地址:点击前往 2.2 安装过程 到 ...

  8. ATM取款机的数据库模拟开发和实战总结

    一.ATM实战开发的简介. 学习了几天的Oracle,开始着手用数据库PL/SQL语言做一个简单的ATM取款机业务,主要是为了巩固数据库的知识,并非真正的去实现高端的业务.有兴趣的可以看看,希望对同胞 ...

  9. linux系统/proc/stat信息与top的cup信息的联系及区别

    一. /proc 目录 Linux系统上的/proc目录是一种文件系统,即proc文件系统,与其它常见的文件系统不同的是,/proc文件系统是一个伪文件系统,它只存在内存当中,而不占用外存空间.它以文 ...

  10. 天云CloudStack 改进版

    整体风格   创建区域