【问题标题】:Configuring MySQL database inside Flask factory function without SQLAlchemy在没有 SQLAlchemy 的 Flask 工厂函数中配置 MySQL 数据库
【发布时间】:2022-01-02 15:07:11
【问题描述】:

我是 Flask 的新手,正在尝试使用 MySQL 数据库构建一个简单的应用程序。但是,我不喜欢使用 SQLAlchemy。相反,我想使用 mysql.connector 并将 SQL 语句直接从数据库中 SELECT、INSERT、UPDATE 或 DELETE。

我有一个问题:是否必须在工厂函数中定义 MySQL 数据库连接/参数? 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

【问题讨论】:

    标签: python python-3.x flask mysql-connector


    【解决方案1】:

    好的,所以我自己找到了解决方案。在工厂函数中定义 MySQL 数据库连接是不是强制性的,使用 SQLALchemy 也是不是必要的。我在一个单独的数据库连接模块中使用了mysql-connector-python,它运行良好。

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

    【讨论】:

      猜你喜欢
      • 2019-08-10
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2018-06-13
      • 2013-02-07
      • 2019-05-04
      • 1970-01-01
      • 2014-12-08
      相关资源
      最近更新 更多