在没有 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,它工作正常。

但是,如果要使用数据库连接池,则需要在工厂函数中创建连接池,以便在启动时对其进行初始化。