robotframwork数据库测试(一)——pymysql与pyodbc

本章节仅总结一下使用pymysql与pyodbc链接MySQL数据库。

2个都可以链接mysql数据,进行增删改查。但是呢,使用pyodbc操作数据库,对中文支持度好一些。pymysql则需要处理一下编码。所以2个都说一下,自己选择哈。



1. 安装DatabaseLibrary,pyodbc,pymysql。

pip install robotframework-databaselibrary

pip install PyMySQL

pip install pyodbc

首推是命令安装,除了命令安装,也可以下载安装包进行安装。cd到安装包目录,python setup.py install即可。



2. 安装、配置MySQL Connector。

1)要用pyodbc连接mysql,还需要一个工具,就是MySQL Connector,地址:http://www.mysql.com/downloads/connector/odbc/

注:一定要下载匹配你的python及pyodbc的版本

查看python版本:

cmd命令:输入python即可查看,如果是32位的,一定要安装32位的mysql connector。

否者,robotframework执行pyodbc链接数据库时,回报错

错误为:(‘IM002‘, ‘[IM002] [Microsoft][ODBC \xc7\xfd\xb6\xaf\xb3\xcc\xd0\xf2\xb9\xdc\xc0\xed\xc6\xf7] \xce\xb4\xb7\xa2\xcf\xd6\xca\xfd\xbe\xdd\xd4\xb4\xc3\xfb\xb3\xc6\xb2\xa2\xc7\xd2\xce\xb4\xd6\xb8\xb6\xa8\xc4\xac\xc8\xcf\xc7\xfd\xb6\xaf\xb3\xcc\xd0\xf2 (0) (SQLDriverConnect)‘)

2)安装完成后,要配置mysql数据源。

操作:打开控制面板-管理工具-ODBC数据源,点击【添加】

选择后进行配置,不知道的,可以百度,百度上有具体的ODBC配置说明。

注:如果安装的是32位的mysql connecter。

        打开控制面板-管理工具-ODBC数据源,点击【添加】,会看不到安装的mysql odbc驱动。

不是没安装好,而是要换个地方配置数据源:运行 C:\Windows\SysWOW64\odbcad32.exe 即可在数据源中找到驱动,进行配置了。

(WOW64什么意思?WOW64(Windows-On-Windows-64bit),在Windows64上面的一个子系统,Windows64位要兼容32位,因此要有一个32位的子系统。)



3. 连接数据,进行查询

1)pymysql

运行结果:

接口.test1
20161108 14:58:54.888 : INFO : @{receiverState} = [ (‘??‘,) | (‘??‘,) | (‘???‘,) | (‘???‘,) | (‘????????‘,) | (‘??‘,) | (‘??‘,) | (‘???‘,) | (‘???‘,) | (‘????????‘,) | (‘??‘,) | (‘??‘,) | (‘???‘,) | (‘???‘,) | (‘????????‘,) ]
20161108 14:58:54.890 : INFO : (‘??‘,)
20161108 14:58:54.890 : INFO : (‘??‘,)
20161108 14:58:54.890 : INFO : (‘???‘,)
20161108 14:58:54.890 : INFO : (‘???‘,)

20161108 14:58:54.893 :  INFO : ??

看结果就发现有一堆???这些都是中文的转码问题,可以写个转码方法也可以去设置。

2)pyodbc

运行结果:

接口.test2
20161108 14:58:54.902 : INFO : @{receiverState} = [ (u‘\u4e0a\u6d77‘, ) | (u‘\u5317\u4eac‘, ) | (u‘\u5c71\u897f\u7701‘, ) | (u‘\u5409\u6797\u7701‘, ) | (u‘\u65b0\u7586\u7ef4\u543e\u5c14\u81ea\u6cbb\u533a‘, ) | (u‘\u4e0a\u6d77‘, ) | (u‘\u5317\u4eac‘, ...
20161108 14:58:54.902 : INFO : (u‘\u4e0a\u6d77‘, )
20161108 14:58:54.902 : INFO : (u‘\u5317\u4eac‘, )
20161108 14:58:54.902 : INFO : (u‘\u5c71\u897f\u7701‘, )
20161108 14:58:54.902 : INFO : (u‘\u5409\u6797\u7701‘, )
20161108 14:58:54.918 :  INFO : 上海

通过该例子是不是很清楚的发现,pyodbc对中文支持对好一些呢。

当然,强大的小伙伴们可以自己写方法,那会更强大了哈。

时间: 2024-11-10 11:23:27

robotframwork数据库测试(一)——pymysql与pyodbc的相关文章

软件测试中的数据库测试

数据库中数据的基本结构 定义一:数据元素集合(也可称数据对象)中各元素的关系. 定义二:相互之间存在特定关系的数据元素集合. 一个表(数据库),我们就称它为一个数据结构,它由很多记录(数据元素)组成,每个元素又包括很多 字段(数据项)组成数据库测试分类系统测试.集成测试.单元测试.功能测试.性能测试.安全测试系统测试.数据库在初期设计中需要进行分析测试. 对于各种数据元素进行完美融合,并理清相互之间的关系便是数据库结构的基本定义. 在数据库中,不同数据之间会存在既定的特殊关系,其属于各种数据元素

数据库测试

数据库测试: 之前写的数据库测试代码稍微有点繁杂,现在我们将这些代码进行简化一下,将备份.还原数据的方法单独写在一个类里,然后测试类继承于这个类. 代码示例: 测试类代码示例: 测试类的代码稍微更改了一下,让测试的覆盖率提高 测试结果: 测量测试覆盖率: 测量测试覆盖率就是测量测试代码运行了多少个测试分支,如果测试代码的全部分支都被运行了,那么测试覆盖率就是100%. 打个比方就是一个猎人挖了100个不同的陷阱,猎人需要一个个的去触碰这些陷阱以确保陷阱没有问[学Java,到凯哥学堂kaige12

DBUnit数据库测试

DBUnit数据库测试: DBUnit是一个基于junit扩展的数据库测试框架.它提供了大量的类对与数据库相关的操作进行了抽象和封装.它通过使用用户自定义的数据集以及相关操作使数据库处于一种可知的状态,从而使得测试自动化.可重复和相对独立.虽然不用dbunit也可以达到这种目的,但是我们必须为此付出代价(编写大量代码,测试及维护),既然有了这么优秀的开源框架,我们又何必再造轮子. 普通的测试数据库的方法不仅较为麻烦,而且在对数据库测试完后会残留数据[学Java,到凯哥学堂kaige123.com

数据库测试DbUnit

DBUnit 的设计理念就是在测试之前,备份数据库,然后给对象数据库植入我们需要的准备数据,最后,在测试完毕后,读入备份数据库,回溯到测试前的状态: 摘自:DbUnit入门实战 DBUnit官网:http://www.dbunit.org/   另外<spring3.x企业应用开发实战>http://pan.baidu.com/s/1eQ7sXoe 密码:yqly    中使用了Unitils Unitils构建在DBUnit与EasyMock项目之上并与JUnit和TestNG相结合.支持数

pxc 数据库测试环境

1.pxc 数据库测试环境:192.168.1.221(主)192.168.1.223(pxc数据库)192.168.1.224(pxc数据库) 修改系统时间• 添加 aliyun yum 源: #cd /etc/yum.repos.d/ # wget http://mirrors.aliyun.com/repo/Centos-6.repo# cp -a Centos-6.repo CentOS-Base.repo 添加aliyun epel yum 源:#wget http://mirrors

Visual Studio 单元测试之五---数据库测试

原文:Visual Studio 单元测试之五---数据库测试 数据库的单元测试主要是测试数据库中的数据是否符合特定的条件,Visual Studio 2010支持下面几种数据的单元测试类型(Visual Studio 2008 不支持数据库测试): 类型 说明 Data Checksum 对数据进行Checksum检验 Empty ResultSet 测试执行的SQL语句返回结果集是否为空 Execution Time 测试执行时间 Expected Schema 测试结果集中的列和数据类型是

Oracle数据库测试和优化最佳实践: OTest介绍 (转)

当前Oracle数据库最佳测试工具OTest *  Otest是用于Oracle数据库测试.优化.监控软件. *  Otest是免费提供给Oracle客户和广大DBA工程师使用的软件.由原厂技术专家王文杰在业余时间开发,并提供支持.发送邮件到[email protected]可以获得支持和最新版本,以及申请cloud版本的key. *Otest 的临时下载地址(版本更新快,新项目上线,最好发邮件申请): 链接:http://pan.baidu.com/s/1eSD1oSq 密码:3ulm

(转)学习使用Jmeter做压力测试(三)--数据库测试

数据库测试 JMeter可以做为Web服务器与浏览器之间的代理网关,以捕获浏览器的请求和Web服务器的响应,这样就可很容易的生成性能测试脚本. 根据脚本,JMeter可通过线程组来模拟真实用户对Web服务器做压力测试.本文描述使用JMeter进行数据库测试的过程.创建测试计划,模拟 并发用户发送SQL请求到数据库.测试数据库. 性能测试的目标是找到系统的性能瓶颈.本文将通过构造测试场景,完成对数据库的测试. 场景: 1.单用户: a.SQL语句优化:    b.数据库约束检查:   c.分页查询

【转】学习使用Jmeter做压力测试(三)--数据库测试

JMeter可以做为Web服务器与浏览器之间的代理网关,以捕获浏览器的请求和Web服务器的响应,这样就可很容易的生成性能测试脚本.根据脚本,JMeter可通过线程组来模拟真实用户对Web服务器做压力测试.本文描述使用JMeter进行数据库测试的过程.创建测试计划,模拟并发用户发送SQL请求到数据库.测试数据库. 性能测试的目标是找到系统的性能瓶颈.本文将通过构造测试场景,完成对数据库的测试. 场景: 1.单用户: a.SQL语句优化:    b.数据库约束检查:   c.分页查询: 2.并发用户