在没有 SQLAlchemy 的 Flask 工厂函数中配置 MySQL 数据库
Configuring MySQL database inside Flask factory function without SQLAlchemy
我是 Flask 的新手,正在尝试使用 MySQL 数据库构建一个简单的应用程序。但是,我不想使用 SQLAlchemy。相反,我想使用 mysql.connector
并将 SQL 语句直接从数据库 SELECT、INSERT、UPDATE 或 DELETE。
我有一个问题:是否必须在工厂函数中定义MySQL数据库connection/parameters? Flask 教程显示了在工厂函数 create_app()
.
中定义的 SQLite 数据库
示例教程代码:
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
好的,所以我自己找到了解决方案。 不是必须在工厂函数中定义MySQL数据库连接,使用SQLALchemy也是不是必须的。我在单独的数据库连接模块中使用了 mysql-connector-python
,它工作正常。
但是,如果要使用数据库连接池,则需要在工厂函数中创建连接池,以便在启动时对其进行初始化。
我是 Flask 的新手,正在尝试使用 MySQL 数据库构建一个简单的应用程序。但是,我不想使用 SQLAlchemy。相反,我想使用 mysql.connector
并将 SQL 语句直接从数据库 SELECT、INSERT、UPDATE 或 DELETE。
我有一个问题:是否必须在工厂函数中定义MySQL数据库connection/parameters? Flask 教程显示了在工厂函数 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
好的,所以我自己找到了解决方案。 不是必须在工厂函数中定义MySQL数据库连接,使用SQLALchemy也是不是必须的。我在单独的数据库连接模块中使用了 mysql-connector-python
,它工作正常。
但是,如果要使用数据库连接池,则需要在工厂函数中创建连接池,以便在启动时对其进行初始化。