定义和访问数据库 — Flask 文档
定义和访问数据库
该应用程序将使用 SQLite 数据库来存储用户和帖子。 Python 在 sqlite3
模块中内置了对 SQLite 的支持。
SQLite 很方便,因为它不需要设置单独的数据库服务器并且是 Python 内置的。 但是,如果并发请求尝试同时写入数据库,它们会随着每次写入顺序发生而变慢。 小型应用程序不会注意到这一点。 一旦你变大了,你可能想切换到不同的数据库。
本教程没有详细介绍 SQL。 如果您不熟悉它,SQLite 文档描述了 语言 。
连接到数据库
使用 SQLite 数据库(和大多数其他 Python 数据库库)时要做的第一件事是创建到它的连接。 任何查询和操作都使用连接执行,工作完成后关闭。
在 Web 应用程序中,此连接通常与请求相关联。 它是在处理请求时的某个时刻创建的,并在发送响应之前关闭。
flaskr/db.py
g 是一个特殊对象,对于每个请求都是唯一的。 它用于存储在请求期间可能被多个函数访问的数据。 如果在同一请求中第二次调用 get_db
,则连接将被存储和重用,而不是创建新连接。
current_app 是另一个特殊对象,指向处理请求的 Flask 应用程序。 由于您使用了应用程序工厂,因此在编写其余代码时没有应用程序对象。 get_db
将在应用程序创建并处理请求时调用,因此可以使用 current_app。
sqlite3.connect()
建立与 DATABASE
配置键指向的文件的连接。 该文件不一定存在,直到您稍后初始化数据库后才会存在。
sqlite3.Row
告诉连接返回行为类似于 dicts 的行。 这允许按名称访问列。
close_db
通过检查是否设置了 g.db
来检查是否创建了连接。 如果连接存在,则关闭。 再往下,您将告诉您的应用程序有关应用程序工厂中的 close_db
函数,以便在每次请求后调用它。
创建表
在 SQLite 中,数据存储在 表 和 列 中。 需要先创建这些,然后才能存储和检索数据。 Flaskr 会将用户存储在 user
表中,并将帖子存储在 post
表中。 使用创建空表所需的 SQL 命令创建一个文件:
flaskr/schema.sql
将运行这些 SQL 命令的 Python 函数添加到 db.py
文件中:
flaskr/db.py
open_resource()
打开一个与 flaskr
包相关的文件,这很有用,因为您在稍后部署应用程序时不一定知道该位置在哪里。 get_db
返回一个数据库连接,用于执行从文件中读取的命令。
click.command()
定义了一个名为 init-db
的命令行命令,该命令调用 init_db
函数并向用户显示成功消息。 您可以阅读 命令行界面 以了解有关编写命令的更多信息。
注册应用程序
close_db
和init_db_command
函数需要在应用实例中注册; 否则,它们将不会被应用程序使用。 但是,由于您使用的是工厂函数,因此在编写函数时该实例不可用。 相反,编写一个接受应用程序并进行注册的函数。
flaskr/db.py
app.teardown_appcontext()
告诉 Flask 在返回响应后清理时调用该函数。
app.cli.add_command()
增加了一个新命令,可以用 flask
命令调用。
从工厂导入并调用此函数。 在返回应用程序之前,将新代码放在工厂函数的末尾。
flaskr/__init__.py