Flask-SQLAlchemy 基于一个base表 - 动态创建使用相同字段的其他业务表

1 安装

首先,确保您安装了 Flask 和 SQLAlchemy,以及 MySQL 的驱动程序(例如 mysql-connector-python 或 PyMySQL):

bash 复制代码
pip install Flask Flask-SQLAlchemy mysql-connector-python

2 创建项目结构

创建一个简单的项目结构:

bash 复制代码
my_flask_app/
│
├── app.py
└── config.py

3 配置文件 (config.py)

config.py 中设置 MySQL 数据库的连接信息:

python 复制代码
class Config:
    SQLALCHEMY_DATABASE_URI = 'mysql+mysqlconnector://username:password@localhost/db_name'
    SQLALCHEMY_TRACK_MODIFICATIONS = False

请将 username、password 和 db_name 替换为您的 MySQL 数据库凭据。

4 创建应用和模型 (app.py)

app.py 中实现创建表的功能:

python 复制代码
from flask import Flask, request, jsonify
from flask_sqlalchemy import SQLAlchemy
from config import Config

app = Flask(__name__)
app.config.from_object(Config)
db = SQLAlchemy(app)

# 定义父表 Base
class Base(db.Model):
    __tablename__ = 'base'
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(50), nullable=False)
    age = db.Column(db.Integer, nullable=False)

# 创建基础表
@app.before_first_request
def create_base_table():
    db.create_all()  # 创建所有模型的表,包括 Base

@app.route('/create_table/<table_name>', methods=['POST'])
def create_table(table_name):
    # 使用动态模型创建与 Base 相同的表
    class DynamicTable(db.Model):
        __tablename__ = table_name  # 设置表名为传入的参数
        id = db.Column(db.Integer, primary_key=True)
        name = db.Column(db.String(50), nullable=False)
        age = db.Column(db.Integer, nullable=False)

    # 创建动态表
    db.create_all()  # 创建新表
    return jsonify({"message": f"Table '{table_name}' created successfully!"})

@app.route('/add_base', methods=['POST'])
def add_base():
    data = request.json
    new_entry = Base(name=data['name'], age=data['age'])
    db.session.add(new_entry)
    db.session.commit()
    return jsonify({"message": "Entry added to base table!"})

if __name__ == '__main__':
    app.run(debug=True)

5 运行应用

确保所有代码已保存,然后在项目目录中运行应用:

bash 复制代码
python app.py

6 测试功能

您可以使用 Postman 或 curl 来测试 API。

  • 创建 base 表(在应用启动时自动创建):
bash 复制代码
curl -X POST -H "Content-Type: application/json" -d '{"name": "John Doe", "age": 30}' http://127.0.0.1:5000/add_base
  • 根据给定的表名创建新表:
bash 复制代码
curl -X POST http://127.0.0.1:5000/create_table/new_table_name

将 new_table_name 替换为您希望创建的表名。

相关推荐
数据村的古老师2 小时前
Python数据分析实战:基于25年黄金价格数据的特征提取与算法应用【数据集可下载】
开发语言·python·数据分析
胡桃姓胡,蝴蝶也姓胡2 小时前
Rag优化 - 如何提升首字响应速度
后端·大模型·rag
小王不爱笑1323 小时前
Java 核心知识点查漏补缺(一)
java·开发语言·python
闲人编程4 小时前
自动化文件管理:分类、重命名和备份
python·microsoft·分类·自动化·备份·重命名·自动化文件分类
Jonathan Star5 小时前
用Python轻松提取视频音频并去除静音片段
开发语言·python·音视频
紫荆鱼6 小时前
设计模式-命令模式(Command)
c++·后端·设计模式·命令模式
编码追梦人6 小时前
深耕 Rust:核心技术解析、生态实践与高性能开发指南
开发语言·后端·rust
刘火锅7 小时前
Java 17 环境下 EasyPoi 反射访问异常分析与解决方案(ExcelImportUtil.importExcelMore)
java·开发语言·python
朝新_7 小时前
【SpringBoot】详解Maven的操作与配置
java·spring boot·笔记·后端·spring·maven·javaee
绝无仅有7 小时前
某教育大厂面试题解析:MySQL索引、Redis缓存、Dubbo负载均衡等
vue.js·后端·面试