我是 Flask 新手,正在尝试使用 MySQL 数据库构建一个简单的应用程序。但是,我不想使用 SQLAlchemy。相反,我想使用mysql.connector
并将 SQL 语句定向到数据库中的 SELECT、INSERT、UPDATE 或 DELETE。
我有个问题:是否必须在工厂函数中定义 MySQL 数据库连接/参数? Flask 教程展示了在工厂函数中定义的 SQLite 数据库,create_app()
.
示例教程代码:
import os
from flask import Flask
def create_app(test_config=None):
# create and configure the app
app = Flask(__name__, instance_relative_config=True)
app.config.from_mapping(
SECRET_KEY='dev',
DATABASE=os.path.join(app.instance_path, 'flaskr.sqlite'),
)
if test_config is None:
# load the instance config, if it exists, when not testing
app.config.from_pyfile('config.py', silent=True)
else:
# load the test config if passed in
app.config.from_mapping(test_config)
# ensure the instance folder exists
try:
os.makedirs(app.instance_path)
except OSError:
pass
# a simple page that says hello
@app.route('/hello')
def hello():
return 'Hello, World!'
return app
好吧,所以我自己找到了解决方案。这是not必须在工厂函数中定义 MySQL 数据库连接,这也是not必须使用 SQLALchemy。我用了mysql-connector-python
在一个单独的数据库连接模块内,它工作得很好。
但是,如果要使用数据库连接池,则需要在工厂函数中创建连接池,以便在启动时对其进行初始化。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)