fqy2022 发表于 2023-2-25 10:08

flask蓝图设计模式pymysql设计问题

问题是这样的: 我用flask蓝图搭建web程序,但是几乎每个试图函数都需要执行sql语句,是不是需要在每个蓝图文件里都重新建立mysql与redis链接(这样就使程序显得很冗余)?有没有更好的解决办法(一次链接程序多个文件都可以调用)?

使用的库: flask+pymysql

希望得到大佬解答!!!

as614001 发表于 2023-2-25 10:23

单独作为一个模块引用

kkoo 发表于 2023-2-25 10:31

引用单独模块

feiyu361 发表于 2023-2-25 11:06

可以单独写一个文件,用来链接mysql,其他文件引用即可

choujie1689 发表于 2023-2-25 12:41

如楼上所说,单独在models新建一个文件,比如叫base.py,然后在其他模块引入:from app.models.base import db

E式丶男孩 发表于 2023-2-25 13:32

建议你使用sqlalchemy,不过即使你不用页游更好的方法
首先你在app.py的包中创建__init__.py
然后你写一个工厂方法,生成app返回,比如createApp()
接下来在createApp()里面挂载一个好了的pymysql实例
你在创建App的时候直接调用createApp()就可以了
此时在蓝图类里面你想调用pymysql的时候就不需要每次获取连接了,你可以直接current_app.xxx来调用

saszznz 发表于 2023-2-27 09:45

页: [1]
查看完整版本: flask蓝图设计模式pymysql设计问题