Flask + MySQL 极简 Web 项目搭建

Flask + MySQL 极简 Web 项目搭建

一、项目结构(超干净)

|------------------------------------------------------------------------------------|
| Plain Text flask_demo/ ├── app.py # 主程序 ├── requirements.txt # 依赖 └── .env # 数据库配置 |

二、requirements.txt(直接复制)

|---------------------------------------------------------------|
| txt flask flask-sqlalchemy pymysql python-dotenv cryptography |

三、.env 数据库配置

|-------------------------------------------------------------------------------------|
| env DB_HOST=localhost DB_USER=root DB_PASSWORD=你的密码 DB_NAME=flask_demo DB_PORT=3306 |

四、[app.py](app.py)(完整可运行代码)

|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| python from flask import Flask, request, jsonify from flask_sqlalchemy import SQLAlchemy from dotenv import load_dotenv import os # 加载环境变量 load_dotenv() # 初始化 Flask app = Flask(name) # 连接 MySQL app.config['SQLALCHEMY_DATABASE_URI'] = f"mysql+pymysql://{os.getenv('DB_USER')}:{os.getenv('DB_PASSWORD')}@{os.getenv('DB_HOST')}:{os.getenv('DB_PORT')}/{os.getenv('DB_NAME')}" app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False # 初始化数据库 db = SQLAlchemy(app) # ==================== 数据库模型 ==================== class User(db.Model): tablename = "users" id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String(50)) email = db.Column(db.String(100), unique=True) age = db.Column(db.Integer) # ==================== 接口(CRUD) ==================== # 1. 创建用户 @app.route('/user', methods=['POST']) def create_user(): data = request.json user = User(name=data['name'], email=data['email'], age=data.get('age')) db.session.add(user) db.session.commit() return jsonify({"msg": "创建成功", "id": user.id}) # 2. 查询所有用户 @app.route('/users', methods=['GET']) def get_users(): users = User.query.all() res = [{"id": u.id, "name": u.name, "email": u.email, "age": u.age} for u in users] return jsonify(res) # 3. 查询单个用户 @app.route('/user/<int:id>', methods=['GET']) def get_user(id): user = User.query.get(id) if not user: return jsonify({"msg": "用户不存在"}), 404 return jsonify({"id": user.id, "name": user.name, "email": user.email, "age": user.age}) # 4. 更新用户 @app.route('/user/<int:id>', methods=['PUT']) def update_user(id): user = User.query.get(id) if not user: return jsonify({"msg": "用户不存在"}), 404 data = request.json user.name = data.get('name', user.name) user.email = data.get('email', user.email) user.age = data.get('age', user.age) db.session.commit() return jsonify({"msg": "更新成功"}) # 5. 删除用户 @app.route('/user/<int:id>', methods=['DELETE']) def delete_user(id): user = User.query.get(id) if not user: return jsonify({"msg": "用户不存在"}), 404 db.session.delete(user) db.session.commit() return jsonify({"msg": "删除成功"}) # 启动时创建表 with app.app_context(): db.create_all() # 启动 if name == 'main': app.run(debug=True) |

五、运行步骤(超级简单)

1. 安装依赖

|--------------------------------------|
| bash pip install -r requirements.txt |

2. 启动项目

|--------------------|
| bash python app.py |

3. 访问地址

|----------------------------------|
| Plain Text http://127.0.0.1:5000 |

4. 接口列表

  • POST /user → 创建用户
  • GET /users → 获取所有用户
  • GET /user/1 → 获取单个用户
  • PUT /user/1 → 更新用户
  • DELETE /user/1 → 删除用户

✅ 这个 Flask 项目特点

  • 代码最少
  • 结构最简单
  • 直接连接 MySQL
  • 完整 CRUD
  • 无命名冲突
  • 可直接运行
相关推荐
q_35488851532 小时前
计算机毕业设计:Python中药材天地网数据挖掘与可视化系统 Django框架 中药数据分析 医药数据分析数据分析 可视化 爬虫 (建议收藏)✅
python·数据挖掘·数据分析·django·flask·课程设计
Soari1 天前
深度办公革命:拆解 Claude for Microsoft 365,打造金融级智能办公生态
python·microsoft·金融·flask
情绪总是阴雨天~1 天前
Flask Web 开发入门笔记
笔记·flask
兄弟加油,别颓废了。1 天前
[特殊字符] SDN 可视化管理平台完整搭建教程(Vue + Flask + MySQL)
vue.js·mysql·flask
Le_ee2 天前
ctfweb:flask+ssti
后端·python·flask
MZ_ZXD0013 天前
springboot音乐播放器系统-计算机毕业设计源码76317
java·c语言·c++·spring boot·python·flask·php
Leinwin4 天前
GPT-5.5 Instant API接入教程:免费额度、速率限制与最佳实践
后端·python·flask
QQ_1880838005 天前
python+flask+vue在线宠物医疗预约平台的设计与实现_b5z03zls
vue.js·python·flask
刀法如飞7 天前
一款开箱即用的Flask 3.0 MVC工程脚手架,面向AI开发
后端·python·flask