这篇文章主要介绍了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
暂无“python 两个数据库postgresql对比”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
2024年11月09日
2024年11月09日
- 雨林唱片《赏》新曲+精选集SACD版[ISO][2.3G]
- 罗大佑与OK男女合唱团.1995-再会吧!素兰【音乐工厂】【WAV+CUE】
- 草蜢.1993-宝贝对不起(国)【宝丽金】【WAV+CUE】
- 杨培安.2009-抒·情(EP)【擎天娱乐】【WAV+CUE】
- 周慧敏《EndlessDream》[WAV+CUE]
- 彭芳《纯色角3》2007[WAV+CUE]
- 江志丰2008-今生为你[豪记][WAV+CUE]
- 罗大佑1994《恋曲2000》音乐工厂[WAV+CUE][1G]
- 群星《一首歌一个故事》赵英俊某些作品重唱企划[FLAC分轨][1G]
- 群星《网易云英文歌曲播放量TOP100》[MP3][1G]
- 方大同.2024-梦想家TheDreamer【赋音乐】【FLAC分轨】
- 李慧珍.2007-爱死了【华谊兄弟】【WAV+CUE】
- 王大文.2019-国际太空站【环球】【FLAC分轨】
- 群星《2022超好听的十倍音质网络歌曲(163)》U盘音乐[WAV分轨][1.1G]
- 童丽《啼笑姻缘》头版限量编号24K金碟[低速原抓WAV+CUE][1.1G]