生成方式
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'"))
👉⚡️