python自動生成model檔案過程詳解
阿新 • • 發佈:2020-01-09
生成方式
Python中想要自動生成 model檔案可以通過 sqlacodegen這個命令來生成對應的model檔案
sqlacodegen 你可以通過pip去安裝:
pip install sqlacodegen
格式:
sqlacodegen mysql+pymysql://username:password@host/database_name > model.py
說明:
- mysql+pymysql : 表示連線資料庫的連線方式
- username : 連線MySQL資料庫的使用者名稱
- password : 連線MySQL資料庫使用者對應的密碼
- host : 資料庫的主機地址
- database_name : 需要生成model的資料庫名【一定是資料庫名】
問題: 如果只想生成資料庫中指定表的model檔案怎麼辦?
答案就是:
給 sqlacodegen 加一個 --table 的引數即可
案例:
👉⚡️sqlacodegen --tables products mysql+pymysql://root:[email protected]/shopify > products.py 👉⚡️ls products.py
結果:
👉⚡️cat products.py # coding: utf-8 from sqlalchemy import CHAR,Column,String,Text,text from sqlalchemy.dialects.mysql import INTEGER from sqlalchemy.ext.declarative import declarative_base Base = declarative_base() metadata = Base.metadata class Product(Base): __tablename__ = 'products' id = Column(INTEGER(16),primary_key=True) title = Column(String(256),nullable=False,server_default=text("''")) product_id = Column(INTEGER(16)) shop_url = Column(String(120)) body_html = Column(Text) vendor = Column(String(64)) product_type = Column(String(64)) created_at = Column(CHAR(30)) updated_at = Column(CHAR(30)) handle = Column(String(256)) published_at = Column(CHAR(30)) template_suffix = Column(String(256)) tags = Column(String(256)) published_scope = Column(CHAR(10),server_default=text("'web'")) 👉⚡️
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。