在Flask中实现对MySQL数据库的增删改查(CRUD)操作,通常需要使用一个数据库ORM(对象关系映射)库,如SQLAlchemy。下面是一个完整的示例,展示了如何在Flask中使用SQLAlchemy实现对MySQL数据库的CRUD操作。
1. 安装依赖首先,你需要安装Flask、Flask-SQLAlchemy和MySQL驱动程序(如mysqlclient或PyMySQL):
pip install Flask Flask-SQLAlchemy mysqlclient2. 配置Flask应用和数据库连接
创建一个新的Flask应用,并配置SQLAlchemy连接到MySQL数据库:
from flask import Flask, request, jsonify
from flask_sqlalchemy import SQLAlchemy
app = Flask(__name__)
# 配置数据库连接
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://username:password@localhost/db_name'
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
db = SQLAlchemy(app)
# 定义数据库模型
class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(80), nullable=False)
email = db.Column(db.String(120), unique=True, nullable=False)
def __repr__(self):
return f'<User {self.name}>'
# 创建数据库表
with app.app_context():
db.create_all() 3. 实现CRUD操作接下来,定义路由来处理增删改查操作:
创建(Create)@app.route('/users', methods=['POST'])
def create_user():
data = request.get_json()
new_user = User(name=data['name'], email=data['email'])
db.session.add(new_user)
db.session.commit()
return jsonify({'message': 'User created successfully'}), 201 读取(Read) @app.route('/users', methods=['GET'])
def get_users():
users = User.query.all()
output = []
for user in users:
user_data = {'id': user.id, 'name': user.name, 'email': user.email}
output.append(user_data)
return jsonify({'users': output})
@app.route('/users/<id>', methods=['GET'])
def get_user(id):
user = User.query.get_or_404(id)
return jsonify({'id': user.id, 'name': user.name, 'email': user.email}) 更新(Update) @app.route('/users/<id>', methods=['PUT'])
def update_user(id):
data = request.get_json()
user = User.query.get_or_404(id)
user.name = data['name']
user.email = data['email']
db.session.commit()
return jsonify({'message': 'User updated successfully'}) 删除(Delete) @app.route('/users/<id>', methods=['DELETE'])
def delete_user(id):
user = User.query.get_or_404(id)
db.session.delete(user)
db.session.commit()
return jsonify({'message': 'User deleted successfully'}) 4. 运行应用最后,添加运行Flask应用的代码:
if __name__ == '__main__':
app.run(debug=True) 完整代码 from flask import Flask, request, jsonify
from flask_sqlalchemy import SQLAlchemy
app = Flask(__name__)
# 配置数据库连接
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://username:password@localhost/db_name'
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
db = SQLAlchemy(app)
# 定义数据库模型
class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(80), nullable=False)
email = db.Column(db.String(120), unique=True, nullable=False)
def __repr__(self):
return f'<User {self.name}>'
# 创建数据库表
with app.app_context():
db.create_all()
@app.route('/users', methods=['POST'])
def create_user():
data = request.get_json()
new_user = User(name=data['name'], email=data['email'])
db.session.add(new_user)
db.session.commit()
return jsonify({'message': 'User created successfully'}), 201
@app.route('/users', methods=['GET'])
def get_users():
users = User.query.all()
output = []
for user in users:
user_data = {'id': user.id, 'name': user.name, 'email': user.email}
output.append(user_data)
return jsonify({'users': output})
@app.route('/users/<id>', methods=['GET'])
def get_user(id):
user = User.query.get_or_404(id)
return jsonify({'id': user.id, 'name': user.name, 'email': user.email})
@app.route('/users/<id>', methods=['PUT'])
def update_user(id):
data = request.get_json()
user = User.query.get_or_404(id)
user.name = data['name']
user.email = data['email']
db.session.commit()
return jsonify({'message': 'User updated successfully'})
@app.route('/users/<id>', methods=['DELETE'])
def delete_user(id):
user = User.query.get_or_404(id)
db.session.delete(user)
db.session.commit()
return jsonify({'message': 'User deleted successfully'})
if __name__ == '__main__':
app.run(debug=True) 总结通过上述步骤,你已经成功地在Flask中实现了对MySQL数据库的CRUD操作。这个示例展示了如何配置数据库连接、定义模型、创建数据库表以及实现增删改查的API端点。
网友回复


