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 替换为您希望创建的表名。

相关推荐
IT_陈寒7 分钟前
React性能优化实战:我用这5个技巧将组件渲染速度提升了70%
前端·人工智能·后端
程序员三明治15 分钟前
SpringBoot YAML 配置读取机制 + 数据库自动初始化原理
数据库·spring boot·后端
Victor35623 分钟前
Redis(130)Redis的压缩列表(Ziplist)是如何实现的?
后端
q***829128 分钟前
Spring Boot 热部署
java·spring boot·后端
Victor35629 分钟前
Redis(131)Redis的整数集合(Intset)是如何实现的?
后端
yuuki2332331 小时前
【数据结构】栈
c语言·数据结构·后端
cheniie1 小时前
python xmlrpc踩坑记录
python·踩坑·xmlrpc
咖啡の猫3 小时前
搭建Python开发环境
开发语言·python
程序猿小蒜4 小时前
基于springboot的共享汽车管理系统开发与设计
java·开发语言·spring boot·后端·spring·汽车
听风吟丶5 小时前
Java 8 Stream API 高级实战:从数据处理到性能优化的深度解析
开发语言·python