这篇文章主要介绍了python 两个数据库postgresql对比,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
比较两个postgresql数据库,原理 比较数据库中各表的大小
1. 数据库查询语句
2. python字典比较
import psycopg2 import sys class PdbModel: def __init__(self, host, dbname, username='postgres', password='postgres', port='5432'): self.host = host self.dbname = dbname self.username = username self.password = password self.port = port self.conn = None self.cursor = None self.init_db() def init_db(self): try: self.conn = psycopg2.connect(database=self.dbname, user=self.username, password=self.password, host=self.host, port="5432") self.cursor = self.conn.cursor() except Exception, e: error_out_print("Error: connection to db %s : %s failed. check need" % (self.host, self.dbname)) print e sys.exit(-1) def execute_sql(self, sql, is_exist=True): """ execute sql and return rows :param sql: :return: results of execute sql """ try: standout_print('command sql : %s' % sql) self.cursor.execute(sql) rows = self.cursor.fetchall() return rows except Exception, e: self.conn.rollback() error_out_print("Failed: failed execute sql [%s]" % sql) error_out_print(e) if is_exist: self.close() sys.exit(-1) else: return None def get_tables_size(self): """ select table_schema || '.' || table_name as table_full_name , pg_size_pretty(pg_total_relation_size('"'||table_schema||'"."'||table_name||'"')) as size from information_schema.tables order by pg_total_relation_size('"'||table_schema||'"."'||table_name||'"') DESC :return: """ standout_print("get the size of tables in db [%s]." % self.dbname) sql = """ select table_schema || '.' || table_name as table_full_name , pg_size_pretty(pg_total_relation_size('"'||table_schema||'"."'||table_name||'"')) as size from information_schema.tables order by pg_total_relation_size('"'||table_schema||'"."'||table_name||'"') DESC """ rows = self.execute_sql(sql) table_size_dic = {} for row in rows: table_name = row[0] table_size = row[1] table_size_dic[table_name] = table_size return table_size_dic def standout_print(info): sys.stdout.write("Info: %s " % info) sys.stdout.flush() def error_out_print(info): sys.stderr.write("Error: %s " % info) sys.stderr.flush() if __name__ == '__main__': db1 = '' db2 = '' host = "172.16.101.92" db_model1 = PdbModel(host, db1) db_model2 = PdbModel(host, db2) table_size_dic1 = db_model1.get_tables_size() table_size_dic2 = db_model2.get_tables_size() import pprint # pprint.pprint(table_size_dic1) # pprint.pprint(table_size_dic2) print cmp(table_size_dic1, table_size_dic2) is_equal = cmp(table_size_dic1, table_size_dic2) different_table_size_dic = {} if is_equal == 0: print "these tables in two database are same." else: keys1 = table_size_dic1.keys() keys2 = table_size_dic2.keys() for key in keys1: value1 = table_size_dic1.get(key) value2 = table_size_dic2.get(key) if cmp(value1, value2) != 0: different_table_size_dic[key] = (value1,value2) pprint.pprint(different_table_size_dic)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“python 两个数据库postgresql对比”评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2025年01月09日
2025年01月09日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]