一周学会Flask3 Python Web开发-SQLAlchemy连接Mysql数据库

锋哥原创的Flask3 Python Web开发 Flask3视频教程:

2025版 Flask3 Python web开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili

app.py下,我们先配置数据库连接,然后写一个简单sql测试。

连接配置,包括用户名,密码,主机地址,端口以及数据库

复制代码
app.config[
    'SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://root:123456@localhost:3308/db_flask?charset=utf8'

接下来创建SQLAlchemy对象:

复制代码
# 创建SQLAlchemy对象
db = SQLAlchemy(app)

写测试连接:

复制代码
with app.app_context():
    with db.engine.connect() as conn:
        rs = conn.execute(text("select 1"))
        print(rs.fetchone())

运行结果:

我们优化下,实际开发,像这些数据库配置,我们都单独写到配置文件里面去:

新建一个config.py

复制代码
# config.py
USERNAME = "root"  # 数据库登录用户名
PASSWORD = "123456"  # 数据库登录密码
HOST = "localhost"  # 数据库服务器地址,若为远程服务器填写对应的IP地址,这里是示例地址
PORT = "3308"  # 数据库连接端口号,MySQL默认常用端口是3306
DATABASE = "db_flask"  # 要访问的数据库名称

# 创建统一资源标识符(URI),用于指定数据库连接的详细信息
# SQLALCHEMY_DATABASE_URI的格式为:数据库类型 + 驱动://{登录名}:{密码}@{IP地址}:{端口号}/{数据库名}?charset={编码格式}
DB_URI = f'mysql+pymysql://{USERNAME}:{PASSWORD}@{HOST}:{PORT}/{DATABASE}?charset=utf8'

# SQLALCHEMY_DATABASE_URI配置项,设置数据库的连接URI,让SQLAlchemy知道如何连接数据库
SQLALCHEMY_DATABASE_URI = DB_URI

# SQLALCHEMY_TRACK_MODIFICATIONS配置项,用于控制是否动态追踪对象修改情况
# 若设置为True,会追踪对象修改,但会消耗额外资源,默认不设置时会有告警提示,这里设为True开启追踪
SQLALCHEMY_TRACK_MODIFICATIONS = True

# SQLALCHEMY_ECHO配置项,用于设置是否在查询时显示原始的SQL语句
# 设为False表示不显示原始SQL语句,设为True则会在控制台等地方输出实际执行的SQL语句,方便调试查看
SQLALCHEMY_ECHO = True

app.py里面读取配置文件

复制代码
# 读取配置文件
app.config.from_object('config')

再测试下,我们还能看到原始SQL信息,方便我们开发调试:

相关推荐
海哥编程25 分钟前
Python 数据分析(二):Matplotlib 绘图
python·数据分析·matplotlib
用户40993225021228 分钟前
FastAPI的查询白名单和安全沙箱机制如何确保你的API坚不可摧?
前端·后端·github
前端小巷子36 分钟前
深入 npm 模块安装机制
前端·javascript·面试
婪苏(Python学习ing)1 小时前
MySQL 与 Redis 基础入门:从安装到核心操作
数据库
go54631584651 小时前
Python点阵字生成与优化:从基础实现到高级渲染技术
开发语言·人工智能·python·深度学习·分类·数据挖掘
猫头虎1 小时前
2025年02月11日 Go生态洞察:Go 1.24 发布亮点全面剖析
开发语言·后端·python·golang·go·beego·go1.19
仰望天空—永强2 小时前
PS 2025【七月最新v26.5】PS铺软件安装|最新版|附带安装文件|详细安装说明|附PS插件
开发语言·图像处理·python·图形渲染·photoshop
幻灭行度2 小时前
通过redis_exporter监控redis cluster
数据库·redis·缓存
cypking2 小时前
electron中IPC 渲染进程与主进程通信方法解析
前端·javascript·electron
MediaTea2 小时前
Python 库手册:xmlrpc.client 与 xmlrpc.server 模块
开发语言·python