python 自動生成model 文件 案例分析


生成方式

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:root@127.0.0.1/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), nullable=False, server_default=text("'web'"))
👉⚡️


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM