Robot Framework(Databaselibrary库操作)

1、安装 DatabaseLibrary 库

DatabaseLibrary 下载地址:
https://pypi.python.org/pypi/robotframework-databaselibrary/0.6
在线文档:
http://franz-see.github.io/Robotframework-Database-Library/
如果像安装普通的 Python 程序,可以下载 tar.gz 文件,解压并运行 setup.py 文件进行安装。

因为在上一小节中我们已经安装了 pip,所以通过 pip 命令安装更为方便和快捷:

现在只安装 DatabaseLibrary 库,Python 操作不同的数据库,还需要安装相应的数据库驱动。
Oracle 数据库驱动:cx_Oracle
https://pypi.python.org/pypi/cx_Oracle
cx_Oracle 是一个用来连接并操作 Oracle 数据库的 Python 扩展模块, 支持包括 Oracle 9.2 10.2
以及 11.1 等版本。
MySQL 数据库驱动:PyMySQL
https://pypi.python.org/pypi/PyMySQL/
这个包含一个纯 python MySQL 客户端库。

2、操作 Oracle 数据库

2.1链接数据库

连接 Oracle 数据:

Connect To Database Using Custom Params :连接 Oracle 数据库关键字。
cx_Oracle:连接 oracle 驱动。
'username','password','192.168.201.138:1521/ORCL' :
连接数据库配置信息,用户名,密码,IP 地址,端口号,数据库名。

2.2执行sql语句

执行 sql 语句:

Execute Sql String 关键字用于执行 sql 语句。注意 sql 语句结尾不要有分号“;”。
Disconnect From Database 关键字用于断开与数据的连接。
sql 语句结果的输出到测试报告:

2.3执行sql文件

执行sql文件:

Execute Sql Script 关键字用于执行 SQL 文件。
${CURDIR} 表示当前项目路径。

2.4添加系统关键字

在 Database Library 库中所提供的 Execute Sql Script 不支持 sql 脚本文件中包含 begin,end 函数,例如:

通过 Execute Sql Script 关键字执行脚本报错:

 

那么就需要我们自己添加关键字了。
找到....\Python27\Lib\site-packages\DatabaseLibrary\ 目录下的 query.py 文件。
创建 execute_sql_funcfile 函数(关键字):

def execute_sql_funcfile(self, sqlScriptFileName):
"""
执行 sql 文件,sql 文件里面带有 begin,end 的函数格式
"""
sqlScriptFile = open(sqlScriptFileName)
cur = None
try:
cur = self._dbconnection.cursor()
sqlStatement = ''
for line in sqlScriptFile:
line = line.strip()
if (line.startswith('/*')==1 and line.endswith('*/')==1):
continue
if line.startswith('#'):
continue
if line.startswith('--'):
continue
if (line.startswith('--')==0 and line.find('--')!=-1):
line =line[:line.find('--')]
if (line == ''):
continue
sqlStatement += line + ' '
sqlStatement = sqlStatement.replace('\n',' ')
print sqlStatement
if len(sqlStatement) != 0:
self.__execute_sql(cur, sqlStatement)
self._dbconnection.commit()
finally:
if cur :
self._dbconnection.rollback()

  然后,在 robot framework 中 F5 搜索 Execute Sql Funcfile 就可以找到我们自定义的关键字了。

执行 SQL 脚本如下:

 

转载于:https://www.cnblogs.com/101718qiong/p/8288207.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值