Python 进行 Oracle 与 Mysql 不同数据库类型之间的数据 diff

分享主题:如何利用Python 进行 Oracle 与 Mysql 不同数据库类型之间的数据 diff

 

一、适用场景

项目工作中,可能会有 A 类型数据库数据需要迁移到 B 类型的数据库中的需求。例如:假设现有一个数据库的迁移需求,是将 Oracle 数据库里的数据迁移至 Mysql 数据库中。常规的测试方法是人工去抽样检测数据进行 diff,因为数据量太大,人工不可能实现全量数据的肉眼 diff。

因此,为提高数据 diff 的正确性以及测试效率,编写测试脚本进行全量迁移数据的 diff 是十分必要的。以下内容将会着重讲解如何使用 Python 编写脚本来实现 Oracle 与 Mysql 这种不同类型数据库之间数据的 diff。

 

二、代码实现

1、连接oracle数据库并获取要提取的数据,并输出列表里面嵌入的字典类型的数据

 1#coding=utf-8
 2import cx_Oracle
 3import pymysql
 4
 5
 6def get_oracle():
 7    conn = cx_Oracle.connect('user''123456''10.7.51.34:1521/server')
 8    cursor=conn.cursor()
 9
10    sql="SELECT NAME_CODE as id ,INDUSTRY_CODE as certificate_no FROM NAME_20201129 WHERE NAME_ID=1"
11    resList1=cursor.execute(sql).fetchall()
12    # print(resList1)
13    columns=[c[0] for c in cursor.description]
14    # print(columns)
15    lastlist=[]
16    for res in resList1:
17        resluts=dict(zip(columns,res))
18        lastlist.append(resluts)
19    print(lastlist)
20    cursor.close

 

2、连接mysql数据库并获取要提取的数据,并输出列表里面嵌入的字典类型的数据

 1def get_mysql():
 2    db = pymysql.connect("10.7.36.42""root""123456""test")
 3    cursor = db.cursor()
 4    sql="select id,certificate_no from test.ticket where id=1"
 5    try:
 6        resultList = []
 7        cursor.execute(sql)
 8        result = cursor.fetchall()
 9        columns = cursor.description
10        for val in result:
11            tempDict = {}
12            for cloNum in range(len(columns)):
13                tempDict[str(columns[cloNum][0]).upper()] = str(val[cloNum]).upper()
14            resultList.append(tempDict)
15        print(resultList)
16        return resultList
17    except:
18        print("Error: unable to fetch data")
19    cursor.close()
20    db.close()

 

3、Oracle 与 Mysql 数据库进行 diff,直接调用上面两个方法即可

1if __name__ == '__main__':
2    get_mysql()
3    get_oracle()

 

4、执行后的输出结果

1[{'ID''82''CERTIFICATE_NO''1CS004398439896'}]
2[{'ID''CO300006484390''CERTIFICATE_NO''CON'}]

 

三、总结

以上代码只是做了一个 diff 的雏形演示,希望能给小伙伴起到抛砖引玉的效果,大家在参考时可以根据自己的需求去做更符合业务场景的 diff 验证。

今天分享的内容实操性比较强,Python 实现代码都是干货,建议动手实操更有助于加深理解哟~

欢迎关注【无量测试之道】公众号,回复【领取资源】
Python编程学习资源干货、
Python+Appium框架APP的UI自动化、
Python+Selenium框架Web的UI自动化、
Python+Unittest框架API自动化、

资源和代码 免费送啦~
文章下方有公众号二维码,可直接微信扫一扫关注即可。

备注:我的个人公众号已正式开通,致力于测试技术的分享,包含:大数据测试、功能测试,测试开发,API接口自动化、测试运维、UI自动化测试等,微信搜索公众号:“无量测试之道”,或扫描下方二维码:

 

添加关注,让我们一起共同成长!

posted on 2021-03-30 13:46  Wu_Candy  阅读(229)  评论(0编辑  收藏  举报