python3 Flask应用 使用 Flask-SQLAlchemy操作MySQL数据库

一、环境搭建

下载命令:

复制代码
pip install flask flask-sqlalchemy pymysql
二、创建项目结构
复制代码
yourProjectFolder/
|------ app.py
|------ config.py
|------ models.py
|__ mydb.py
三、基本使用

3.1 config.py进行数据库连接配置

复制代码
import os

basedir = os.path.abspath(os.path.dirname(__file__))


class Config(object):
    SECRET_KEY = os.environ.get('SECRET_KEY') or 'you-will-never-guess'
    SQLALCHEMY_DATABASE_URI = 'mysql+pymysql://用户名:密码@数据库地址/数据库名'
    SQLALCHEMY_TRACK_MODIFICATIONS = False  # 关闭修改跟踪,节省资源

3.2 models.py 定义数据库模型

复制代码
from flask_sqlalchemy import SQLAlchemy

db = SQLAlchemy()

class User(db.Model):
    __tablename__ = 'user'

    id = db.Column(db.BigInteger, primary_key=True, autoincrement=True, comment='主键id')
    username = db.Column(db.String(255), index=True, unique=True, nullable=False, comment='用户名(手机号)')
    password = db.Column(db.String(255), nullable=False, comment='密码')
    ip = db.Column(db.String(255), nullable=True, default=None, comment='注册时IP地址')
    ipCity = db.Column(db.String(255), nullable=True, default=None, comment='注册时的ip所在地')
    registerTime = db.Column(db.String(255), nullable=True, default=None, comment='注册时间')

    def __repr__(self):
        return '<User {}>'.format(self.username)

3.3 mydb.py 增删改查例子

复制代码
from flask import Flask
from sqlalchemy.exc import SQLAlchemyError

from config import Config
from models import db, User


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

# 初始化数据库
db.init_app(app)


# 新增例子
def insert(username, password, ip, ip_city, register_time):
    is_user = login_user_db(username)
    if is_user is not None:
        return 1
    else:
        with app.app_context():
            try:
                u = User(username=username, password=password, ip=ip, ipCity=ip_city, registerTime=register_time)
                db.session.add(u)
                db.session.commit()
                return 2
            except Exception as e:
                db.session.rollback()
                print(f"发生错误: {e}")
                return 3


# 查询例子
def select(username):
    with app.app_context():
        return User.query.filter_by(username=username).first()
        # 稍微复杂一点的查询
        # return User.query.filter(User.username.like('%john%')).first()


# 修改例子
def update(username,password):
    with app.app_context():
        try:
            user = User.query.filter_by(username=username).first()
            if user:
                user.password = str(password)
                db.session.commit()
                return True
            else:
                print(f"密码重置用户 {username} 没有.")
                return False
        except SQLAlchemyError as e:
            db.session.rollback()
            print(f"An error occurred: {e}")
            return False


# 删除例子
def delete(username):
    with app.app_context():
        try:
            # 查找用户 通过用户名
            user = User.query.filter_by(username=username)
            # .get()方法用的是主键
            # user = User.query.get(1) 
            if user:
                db.session.delete(user)  # 删除用户
                db.session.commit()  # 提交事务
                return True
            else:
                print(f"没有找到用户 {username}.")
                return False
        except SQLAlchemyError as e:
            db.session.rollback()  # 回滚事务
            print(f"An error occurred: {e}")
            return False

3.3 app.py 调用 增删该查例子

复制代码
import mydb

mydb.update(username=username, password=password)
db_user = mydb.select(username)
db_user.id
db_user.username
db_user.password
相关推荐
科技小花7 小时前
全球化深水区,数据治理成为企业出海 “核心竞争力”
大数据·数据库·人工智能·数据治理·数据中台·全球化
X56618 小时前
如何在 Laravel 中正确保存嵌套动态表单数据(主服务与子服务)
jvm·数据库·python
虹科网络安全9 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
2301_771717219 小时前
解决mysql报错:1406, Data too long for column
android·数据库·mysql
绘梨衣5479 小时前
Docker+FastAPI+MySQL 项目部署报错汇总
mysql·docker·fastapi
小江的记录本10 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
dvjr cloi10 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
dFObBIMmai10 小时前
MySQL主从同步中大事务导致的延迟_如何拆分大事务优化同步
jvm·数据库·python
szccyw010 小时前
mysql如何限制特定存储过程执行权限_MySQL存储过程安全访问
jvm·数据库·python
czlczl2002092511 小时前
利用“延迟关联”优化 MySQL 巨量数据的深分页查询
数据库·mysql