1. 程式人生 > 程式設計 >python自動生成model檔案過程詳解

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:[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'"))
👉⚡️

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。