postgres数据库使用sqlacodegen将已存在的表生成对应的model
2022/7/13 2:21:31
本文主要是介绍postgres数据库使用sqlacodegen将已存在的表生成对应的model,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
需要安装的包如下: greenlet==1.1.2 importlib-metadata==4.12.0 inflect==5.6.1 psycopg2==2.9.3 sqlacodegen==3.0.0rc1 SQLAlchemy==1.4.39 zipp==3.8.0 代码如下:
import os from tools.db import DB import threading def gen_table_model(tablename): os.system(f'sqlacodegen postgresql+psycopg2://username:password@192.168.80.150:5432/dbname --tables {tablename}> ./3.0.0/{tablename}.py') if __name__ == '__main__': db = DB("192.168.80.150", "5432", "username", "password", "dbname") db.connect() all_tables = db.fetch_all("SELECT tablename FROM pg_tables WHERE tablename not LIKE 'pg%' AND tablename NOT LIKE 'sql_%' ORDER BY tablename;") db.close() table_list = [] for table in all_tables: print(table) print(type(table)) for t in table: table_list.append(t) threads=[] for table in table_list: threads.append( threading.Thread(target=gen_table_model,args=(table,)) ) for thread in threads: thread.start() for thread in threads: thread.join()
注意,由于数据库自增值的类型是identity,这个转换时只有在sqlacodegen 3.0.0版本才生效,如果使用2.4.x版本,会报错。
这篇关于postgres数据库使用sqlacodegen将已存在的表生成对应的model的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23增量更新怎么做?-icode9专业技术文章分享
- 2024-11-23压缩包加密方案有哪些?-icode9专业技术文章分享
- 2024-11-23用shell怎么写一个开机时自动同步远程仓库的代码?-icode9专业技术文章分享
- 2024-11-23webman可以同步自己的仓库吗?-icode9专业技术文章分享
- 2024-11-23在 Webman 中怎么判断是否有某命令进程正在运行?-icode9专业技术文章分享
- 2024-11-23如何重置new Swiper?-icode9专业技术文章分享
- 2024-11-23oss直传有什么好处?-icode9专业技术文章分享
- 2024-11-23如何将oss直传封装成一个组件在其他页面调用时都可以使用?-icode9专业技术文章分享
- 2024-11-23怎么使用laravel 11在代码里获取路由列表?-icode9专业技术文章分享
- 2024-11-22怎么实现ansible playbook 备份代码中命名包含时间戳功能?-icode9专业技术文章分享