python用sqlacodegen根據(jù)已有數(shù)據(jù)庫(表)結構生成對應SQLAlchemy模型
今天介紹一個后臺開發(fā)神器,很適合當我們數(shù)據(jù)庫中已存在了這些表,然后你想得到它們的model類使用ORM技術進行CRUD操作(或者我根本就不知道怎么寫modle類的時候);
手寫100張表的model類?
這是。。。。。。。。。 是不可能的,這輩子都不可能的。
因為我們有sqlacodegen神器, 一行命令獲取數(shù)據(jù)庫所有表的模型類。
應用場景
1、后臺開發(fā)中,需要經(jīng)常對數(shù)據(jù)庫進行CRUD操作;
2、這個過程中,我們就經(jīng)常借助ORM技術進行便利的CURD,比如成熟的SQLAlchemy;
3、但是,進行ORM操作前需要提供和table對應的模型類;
4、并且,很多歷史table已經(jīng)存在于數(shù)據(jù)庫中;
5、如果有幾百張table呢?還自己一個個去寫嗎?
6、我相信你心中會有個念頭。。。
福音
還是那句話,Python大法好。 這里就介紹一個根據(jù)已有數(shù)據(jù)庫(表)結構生成對應SQLAlchemy模型類的神器: sqlacodegen
This is a tool that reads the structure of an existing database and generates the appropriate SQLAlchemy model code, using the declarative style if possible.
安裝方法:
pip install sqlacodegen
快快使用
使用方法也很簡單,只需要在終端(命令行窗口)運行一行命令即可, 將會獲取到整個數(shù)據(jù)庫的model:
常用數(shù)據(jù)庫的使用方法:
sqlacodegen postgresql:///some_local_db sqlacodegen mysql+oursql://user:password@localhost/dbname sqlacodegen sqlite:///database.db
查看具體參數(shù)可以輸入:
sqlacodegen --help
參數(shù)含義:
optional arguments: -h, --help show this help message and exit --version print the version number and exit --schema SCHEMA load tables from an alternate schema --tables TABLES tables to process (comma-separated, default: all) --noviews ignore views --noindexes ignore indexes --noconstraints ignore constraints --nojoined don't autodetect joined table inheritance --noinflect don't try to convert tables names to singular form --noclasses don't generate classes, only tables --outfile OUTFILE file to write output to (default: stdout)
目前我在postgresql的默認的postgres數(shù)據(jù)庫中有個這樣的表:
create table friends ( id varchar(3) primary key , address varchar(50) not null , name varchar(10) not null ); create unique index name_address on friends (name, address);
為了使用ORM進行操作,我需要獲取它的modle類但唯一索引的model類怎么寫呢? 我們借助sqlacodegen來自動生成就好了
sqlacodegen postgresql://ridingroad:ridingroad@127.0.0.1:5432/postgres --outfile=models.py --tables friends
模型類效果
查看輸出到models.py的內容
# coding: utf-8 from sqlalchemy import Column, Index, String from sqlalchemy.ext.declarative import declarative_base Base = declarative_base() metadata = Base.metadata class Friend(Base): __tablename__ = 'friends' __table_args__ = ( Index('name_address', 'name', 'address', unique=True), ) id = Column(String(3), primary_key=True) address = Column(String(50), nullable=False) name = Column(String(10), nullable=False)
如果你有很多表,就直接指定數(shù)據(jù)庫唄(這是會生成整個數(shù)據(jù)庫的ORM模型類哦),不具體到每張表就好了, 后面就可以愉快的CRUD了,耶
注意事項
Why does it sometimes generate classes and sometimes Tables?
Unless the --noclasses option is used, sqlacodegen tries to generate declarative model classes from each table. There are two circumstances in which a Table is generated instead: 1、the table has no primary key constraint (which is required by SQLAlchemy for every model class) 2、the table is an association table between two other tables
當你的表的字段缺少primary key或這張表是有兩個外鍵約束的時候,會生成table而不是模型類了。比如,我那張表是這樣的結構:
create table friends ( id varchar(3) , address varchar(50) not null , name varchar(10) not null ); create unique index name_address on friends (name, address);
再執(zhí)行同一個命令:
sqlacodegen postgresql://ridingroad:ridingroad@127.0.0.1:5432/postgres --outfile=models.py --tables friends
獲取到的是Table:
# coding: utf-8 from sqlalchemy import Column, Index, MetaData, String, Table metadata = MetaData() t_friends = Table( 'friends', metadata, Column('id', String(3)), Column('address', String(50), nullable=False), Column('name', String(10), nullable=False), Index('name_address', 'name', 'address', unique=True) )
其實和模型類差不多嘛,但是還是盡量帶上primary key吧,免得手動修改成模型類
以上就是python用sqlacodegen根據(jù)已有數(shù)據(jù)庫(表)結構生成對應SQLAlchemy模型的詳細內容,更多關于python sqlacodegen的使用的資料請關注腳本之家其它相關文章!
相關文章
TensorFlow的reshape操作 tf.reshape的實現(xiàn)
這篇文章主要介紹了TensorFlow的reshape操作 tf.reshape的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-04-04使用 Python 創(chuàng)建一個基于規(guī)則的聊天機器人
這篇文章主要介紹了使用 Python 創(chuàng)建一個基于規(guī)則的聊天機器人,使用 Python 創(chuàng)建一個簡單的基于規(guī)則的聊天機器人 聊天機器人本身是一種機器或軟件,它通過文本或句子模仿人類交互。 簡而言之,可以使用類似于與人類對話的軟件進行聊天。2021-10-10用TensorFlow實現(xiàn)lasso回歸和嶺回歸算法的示例
本篇文章主要介紹了用TensorFlow實現(xiàn)lasso回歸和嶺回歸算法的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05