mysql 读取oracle_RobotFramework读取mysql和oracle数据库

一、robotframework连接mysql数据库

1、安装databaselibrary、pymysql

通过cmd命令执行:pip install robotframework-databaselibrary

57bbf79fc29c99d76794bfb116465d6d.png

cmd命令执行:pip install pymysql

40c04fa1c564595933a453e1b3cf1205.png

2、导入DatabaseLibrary包到Robotframework

3b26b8808182b560760be0baa5121d10.png

3、使用关键字对数据库进行操作

连接数据库:Connect to database using custom params

这个关键字需要传入2个参数,pymysql、及数据库连接信息(host='数据库ip',port='数据库端口',user='数据库登陆用户名',passwd='密码',db='数据库名(不是表名)')

dffa4ade496f0233d67133b00181b2d6.png

执行查询语句:Query

170d03f0452edba66373e73e294769d9.png

执行增删改语句:Execute Sql String

9f4ccd9e4ebc894061cee82886822829.png

断开数据库连接:Disconnect From Database

b437b89b7613e30c88857bdb61eb9bd0.png

注意:sql语句结尾尽量不要用分号,每次连接数据库后都使用断开数据库连接结束

二、robotframework连接Oracle数据库连接

1、安装DatabaseLibrary(见连接mysql数据库操作)

2、安装cx_Oracle,DatabaseLibrary,进入cx_oracle下载页面,下载python对应的版本号:http://sourceforge.net/projects/cx-oracle/files/

下载完后直接安装,安装完成后,在你的 \Python27\Lib\site-packages目录下,可以看到Database Library文件夹和cx_Oracle.pyd文件;

a8f5081dbb107b1b737d0d82e58ea5f6.png

3、将本地连接oracle数据库的oci文件复制到site-packages目录

7ba12170d10ebc07685673994b5d2b5e.png

4、使用关键字进行oracle数据库操作

连接数据库:Connect To Database Using Custom Params;需要传入2个参数;cx_Oracle和数据库连接信息--    '账号','密码','ip:端口/ORCL

2432432e68618251883ab7ecd52fd0c8.png

查询和修改关键字跟mysql操作相同;

常见问题:

1、数据库查询内容包含[(u')返回值',)]  见下图,[(u'YIN',)]

774dc29db17f640a87be90bedd28b493.png

解决办法:通过截取方式去除:{serID[0][0]}

326254f453a57af383b40c5e608c249c.png

执行结果:

0e6902d9883f1d54312342ec30113c02.png

2、数据库执行sql带中文报错:UnicodeEncodeError:'ascii' codec can't encode characters in position 59-65....

8845a76f34d7b4e00f26a533be463028.png

解决办法:新建一个文件sitecustomize.py放到C:\Python27\Lib\site-packages(以你实际的python安装目录为准):

# -*- coding: utf-8 -*-

import sys

import os

import cx_Oracle

reload(sys)

sys.setdefaultencoding('utf-8')

os.environ['NLS_LANG'] = 'SIMPLIFIED CHINESE_CHINA.UTF8'

保存后重启robotframework,sql能正常执行;

e56a0f2f9f00b7680a24884f2831b352.png

3、数据库sql语句查询返回乱码:

4cb2cc268faa5ea9f1e9b5685a54d15c.png

解决办法:在C:\Python27\Lib\site-packages\DatabaseLibrary\query.py文件中添加如下代码:

def decode(self,code):

return code.decode('utf-8')

34d6b1d303bb7f48083d5a48a175aa2e.png

保存后先用python工具编译一下,然后重启robotframework;然后使用decode进行转译;

ccadaf85a2b95eb6a9d4549fbc8ebb5e.png

运行得到中文:

b1c84096963a7428a58ce04f85d56449.png

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值