Astro DB
Astro DB 是一款专为 Astro 设计的全托管 SQL 数据库。在 Astro 中进行本地开发并部署到任何与 libSQL 兼容的数据库。
Astro DB 是一种配置、开发和查询数据的完整解决方案。每当你运行astro dev
时,都会在.astro/content.db
中创建一个本地数据库来管理数据,而无需 Docker 或网络连接。
安装
段落标题 安装使用内置的 astro add
命令安装 @astrojs/db
集成:
定义你的数据库
段落标题 定义你的数据库使用 astro add
命令安装 @astrojs/db
将自动在你的项目中创建一个 db/config.ts
文件,你可以在其中定义你的数据库表:
Astro DB 中的数据是通过 SQL 表存储的。表将你的数据结构化为行和列,其中列强制每行值的类型。
通过提供现有 libSQL 数据库中的数据结构或将在新数据库中收集的数据,在 db/config.ts
文件中定义表。这将允许 Astro 为你的项目生成一个 TypeScript 接口来查询该表。这意味着当你访问数据时,将获得完整的 TypeScript 支持,包括属性自动完成和类型检查。
要配置数据库表,应从 astro:db
导入并使用 defineTable()
和 column
工具。然后,为表定义一个名称(区分大小写)以及每列的数据类型。
这个例子配置了一个 Comment
表,它有 author
和 body
的必需文本列。然后,通过 defineDb()
导出使其在你的项目中可用。
Astro DB 支持以下列类型:
表引用
段落标题 表引用表之间的关系是数据库设计中的常见架构。例如,一个 Blog
表可能与 Comment
、Author
和 Category
等其他几个表密切相关。
你可以使用引用列定义来这些表之间的关系并将它们保存到你的数据库中。要建立关系,你需要:
- 在被引用的表上有一个标识符列。这通常是带有
primaryKey
属性的id
列。 - 在基础表上有一个用于存储被引用
id
的列。这将使用references
属性来建立关系。
这个例子显示了一个 Comment
表的 authorId
列引用了 Author
表的 id
列。
为你的开发数据库填充数据
段落标题 为你的开发数据库填充数据在开发过程中,Astro 将使用你的 DB 配置并根据你的架构生成本地类型。这些内容将在每次启动开发服务器时从你的 seed 文件重新生成,并允许你使用类型安全和自动补全来查询和处理你的数据样例。
你将无法在开发过程中访问生产数据,除非你在开发过程中 连接到远程数据库。这样可以保护你的数据,同时允许你使用类型安全的工作数据库进行测试和开发。
要为你的 Astro 项目填充开发数据进行测试和调试,你需要创建一个 db/seed.ts
文件。导入 db
对象和 astro:db
中定义的表。insert
一些初始数据到每一个表中。这些开发数据应该与数据库模式和生产数据的结构相匹配。
以下例子为 Comment
表和 Author
表定义了两行开发数据:
你的开发服务器将在此文件更改时自动重启你的数据库,并每次重新生成类型并从 seed.ts
填充新的开发数据。
连接一个 libSQL 数据库用于生产
段落标题 连接一个 libSQL 数据库用于生产Astro DB 可以连接到任何本地 libSQL 数据库或任何暴露 libSQL 远程协议的托管或自托管服务器。
要连接 Astro DB 到 libSQL 数据库,设置以下从你的数据库提供商获取的环境变量:
ASTRO_DB_REMOTE_URL
:连接到本地或远程 libSQL DB 的位置的连接 URL。这可能包括 URL 配置选项 如 sync 和 encryption 作为参数。ASTRO_DB_APP_TOKEN
:你的 libSQL 服务器的认证 token。这对远程数据库是必须的,对 本地 DB 如 文件或内存 数据库不是必须的。
根据你的服务,你可能会访问到一个 CLI 或 web UI 来获取这些值。以下部分将演示连接到 Turso 并设置这些值,但你也可以使用任何提供商。
开始使用 Turso
段落标题 开始使用 TursoTurso 是 libSQL 背后的公司,libSQL 是 Astro DB 的底层数据库。他们提供了一个完全托管的 libSQL 数据库平台,并与 Astro 完全兼容。
以下步骤将引导你完成安装 Turso CLI、登录(或注册)、创建一个新数据库、获取所需的认证环境变量,并将模式推送到远程数据库的过程。
-
安装 Turso CLI。
-
登录或注册 Turso。
-
创建一个新数据库。在这个例子中,数据库名称为
andromeda
。 -
运行
show
命令查看新创建数据库的信息:复制
URL
值并将其设置为ASTRO_DB_REMOTE_URL
的值。 -
创建一个新 token 认证请求到数据库:
复制命令的输出并将其设置为
ASTRO_DB_APP_TOKEN
的值。 -
将你的 DB schema 和 metadata 推送到新的 Turso 数据库。
-
恭喜,现在你已经连接了一个数据库!给自己一个奖励。 👾
要探索更多 Turso 的功能,请查看 Turso 文档。
连接到远程数据库
段落标题 连接到远程数据库Astro DB 允许你连接到本地和远程数据库。默认情况下,Astro 使用一个本地数据库文件用于 dev
和 build
命令,每次重新创建表并插入开发 seed 数据。
要连接到一个托管的远程数据库,使用 --remote
标志。这个标志允许你访问远程数据库,允许你 接受和持久化用户数据 在生产环境中。
虽然远程连接在任何使用静态或服务器渲染模式的部署平台上都是可能的,但目前存在一些限制。非 Node 运行时(如 Cloudflare 和 Deno)不支持在 libSQL 上使用服务器渲染路由时使用 DB。对于这些平台的支持,计划将在未来中实现。
配置你的 build 命令使用 --remote
标志:
你也可以直接在命令行中使用该标志:
在开发过程中使用 --remote
时请小心。这会连接到你的生产数据库,所有更改(插入、更新、删除)都会被持久化。
--remote
标志在本地构建期间和服务器上都使用远程数据库连接。确保在本地开发环境和部署平台中都设置了必要的环境变量。
当你部署你的 Astro DB 项目时,确保你的部署平台的 build 命令设置为 npm run build
(或你包管理器的等效命令)以使用在 package.json
中配置的 --remote
标志。
远程 URL 配置选项
段落标题 远程 URL 配置选项ASTRO_DB_REMOTE_URL
环境变量配置了数据库的位置以及同步和加密等其他选项。
URL scheme 和 host
段落标题 URL scheme 和 hostlibSQL 支持 HTTP 和 WebSockets 作为远程服务器的传输协议。它还支持使用本地文件或内存数据库。可以使用以下 URL 方案在连接 URL 中进行配置:
memory:
将使用内存数据库。在这种情况下,主机必须为空。file:
将使用本地文件。主机是文件的路径 (file:path/to/file.db
).libsql:
将通过 libSQL 库首选的协议使用远程服务器(这可能因版本而异)。主机是服务器的地址 (libsql://your.server.io
).http:
通过 HTTP 使用远程服务器。https:
可以用来启用安全连接。主机与libsql:
相同。ws:
通过 WebSockets 使用远程服务器。wss:
可以用来启用安全连接。主机与libsql:
相同。
libSQL 连接的详细信息(例如加密密钥、复制、同步间隔)可以在远程连接 URL 中作为查询参数进行配置。
例如,要将一个加密的本地文件设置为 libSQL 服务器的嵌入式副本,可以设置以下环境变量:
使用数据库文件是一个高级特性,在部署时应该小心,以防止覆盖你的数据库并丢失你的生产数据。
此外,这种方法在无服务器部署中将无法工作,因为这些环境中没有持久化的文件系统。
encryptionKey
段落标题 encryptionKeylibSQL 对加密数据库有原生支持。传递这个搜索参数将使用给定的密钥启用加密:
syncUrl
段落标题 syncUrl嵌入式副本是 libSQL 客户端的一个特性,它会在本地文件或内存中创建一个完整同步的副本,以实现超快的读取。写入发送到在 syncUrl
上定义的远程数据库,并与本地副本同步。
使用此属性传递一个单独的连接 URL 将数据库转换为另一个数据库的嵌入式副本。这应该仅与 file:
和 memory:
方案一起使用。该参数必须进行 URL 编码。
例如,要将一个数据库设置为 libsql://your.server.io
的内存嵌入式副本,可以设置连接 URL 如下:
syncInterval
段落标题 syncInterval嵌入式副本之间同步的间隔时间,单位为秒。默认情况下,它仅在启动时和写入后同步。
此属性仅在设置 syncUrl
时使用。例如,要将内存嵌入式副本设置为每分钟同步,请设置以下环境变量:
查询你的数据库
段落标题 查询你的数据库你可以从项目中的任何 Astro 页面,端点 或 action 使用提供的 db
ORM 和查询构建器来查询你的数据库。
Drizzle ORM
段落标题 Drizzle ORMAstro DB 包含一个内置的 Drizzle ORM 客户端。使用该客户端无需设置或手动配置。当你运行 Astro 时,Astro DB 的 db
客户端会自动配置以与你的数据库(本地或远程)进行通信。它使用你明确的数据库架构定义进行类型安全的 SQL 查询,当你引用不存在的列或表时,会出现 TypeScript 错误。
查询
段落标题 查询以下例子选择了 Comment
表的所有行。这将返回来自 db/seed.ts
全量的填充的开发数据数组,然后可以在你的页面模板中使用它们:
select()
API 参考 以获取完整概述。
插入
段落标题 插入要接受用户输入,如处理表单请求并将数据插入到你的远程托管数据库,需要为你的 Astro 项目配置 按需渲染 并为你的部署环境 添加一个 SSR 适配器。
这个例子基于解析后表单的 POST 请求向 Comment
表插入一行:
你也可以使用 Astro actions 向 Astro DB 表中插入数据。以下例子使用一个 action 向 Comment
表中插入一行:
查看 Drizzle insert()
API 参考 以获取完整概述。
删除
段落标题 删除你也可以从 API 端点查询你的数据库。这个例子通过 id
参数删除 Comment
表中的一行:
查看 Drizzle delete()
API 参考 以获取完整概述。
过滤
段落标题 过滤要通过特定属性查询表结果,请使用 Drizzle 的部分查询选项。例如,向你的 select()
查询添加 一个 .where()
调用,并传递你想做的比较操作。
以下例子查询了 Comment
表中包含 “Astro DB” 短语的所有行。使用 like()
操作符 检查 body
中是否存在短语:
Drizzle 辅助工具
段落标题 Drizzle 辅助工具所有用于构建查询的 Drizzle 辅助工具都从 astro:db
模块中暴露出来。这包括:
关系
段落标题 关系你可以使用 SQL 连接从多个表查询关联的数据。要创建一个连接查询,请使用连接操作符扩展你的 db.select()
语句。每个函数都接受一个要连接的表和一个条件来匹配两个表之间的行。
这个例子使用了 innerJoin()
函数将 Comment
的作者与他们相关的 Author
信息连接起来,基于 authorId
列。这将返回一个对象数组,每个 Author
和 Comment
行作为顶级属性:
查看 Drizzle 连接参考 以获取所有可用的连接操作符和配置选项。
批处理事务
段落标题 批处理事务所有远程数据库查询都作为网络请求进行。当进行大量查询,或者如果任何查询失败需要自动回滚时,你可能需要将查询批量处理为单个事务。
这个例子使用 db.batch()
方法在单个请求中填充多行:
查看 Drizzle db.batch()
文档以获取更多详细信息。
将更改推送到你的数据库
段落标题 将更改推送到你的数据库你可以将开发期间所做的更改推送到你的数据库。
推送表架构
段落标题 推送表架构你的表架构可能会随着项目的增长而变化。你可以在本地安全地测试配置更改,并在部署时推送到你的远程数据库。
你可以通过 CLI 使用 astro db push --remote
命令将本地架构更改推送到远程数据库:
此命令将验证你的本地更改是否可以在不丢失数据的情况下进行,并在必要时,建议如何安全地修改你的架构以解决冲突。
推送破坏性架构更改
段落标题 推送破坏性架构更改这将销毁你的数据库。仅在你不需要生产数据时执行此命令。
如果必须以与现有数据不兼容的方式更改表架构,则需要重置生产数据库。
要推送包含破坏性更改的表架构更新,请添加 --force-reset
标志以重置所有生产数据:
重命名表
段落标题 重命名表在将架构推送到远程数据库后,可以重命名表。
如果 没有重要的生产数据,则可以使用 --force-reset
标志 重置你的数据库。此标志将删除数据库中的所有表并创建新的表,以匹配当前的架构。
为了在保留你的生产数据的同时重命名一个表,你必须执行一系列非破坏性更改,以安全地将本地架构推送到远程数据库。
以下示例将表从 Comment
重命名为 Feedback
:
-
在你的数据库配置文件中,为你想要重命名的表添加
deprecated: true
属性: -
添加一个新的表架构(完全匹配现有表的属性)并使用新名称:
-
使用
astro db push --remote
将架构推送到远程数据库 。这将添加新表并将旧表标记为已弃用。 -
更新你的本地项目代码以使用新表而不是旧表。你可能还需要将数据迁移到新表。
-
一旦你确信旧表在你的项目中不再使用,你可以从
config.ts
中删除旧表的架构: -
再次使用
astro db push --remote
推送到远程数据库。旧表将被删除,只留下新的、重命名的表。
推送表数据
段落标题 推送表数据你可能需要将数据推送到远程数据库以进行填充或数据迁移。你可以编写一个 .ts
文件并使用 astro:db
模块来编写类型安全的查询。然后,使用命令 astro db execute <file-path> --remote
对远程数据库执行该文件:
以下评论可以使用命令 astro db execute db/seed.ts --remote
进行填充:
查看 CLI 参考 以获取完整的命令列表。
构建 Astro DB 集成
段落标题 构建 Astro DB 集成Astro 集成 可以通过额外的 Astro DB 表和填充数据来扩展用户项目。
在 astro:db:setup
钩子中使用 extendDb()
方法注册额外的 Astro DB 配置和填充文件。
defineDbIntegration()
辅助函数为 astro:db:setup
钩子提供 TypeScript 支持和自动补全。
集成的 配置 和 填充 文件遵循与其用户定义的等效项相同的格式。
在集成中进行类型安全操作
段落标题 在集成中进行类型安全操作在进行集成工作时,你可能无法从 astro:db
导出的 Astro 生成的表类型中获益。
为了完全的类型安全,使用 asDrizzleTable()
辅助工具创建一个可以用于数据库操作的表引用对象。
例如,给定一个集成设置以下 Pets
数据库表:
填充文件可以导入 Pets
并使用 asDrizzleTable()
向你的表插入具有类型检查的行:
asDrizzleTable('Pets', Pets)
返回的值等同于 import { Pets } from 'astro:db'
,但即使 Astro 的类型生成无法运行时也可用。
你可以在任何需要查询或插入数据库的集成代码中使用它。
从 Astro Studio 迁移到 Turso
段落标题 从 Astro Studio 迁移到 Turso- 在 Studio 仪表板 中,导航到你要迁移的项目。在设置选项卡中,使用 “Export Database(导出数据库)” 按钮下载数据库的转储。
- 按照官方说明 安装 Turso CLI 并 注册或登录 你的 Turso 帐户。
- 使用
turso db create
命令在 Turso 上创建一个新数据库。 - 使用 Turso CLI 获取数据库 URL,并将其配置为环境变量
ASTRO_DB_REMOTE_URL
。 - 创建一个令牌来访问你的数据库,并将其配置为环境变量
ASTRO_DB_APP_TOKEN
。 - 将你的 DB 架构和元数据推送到新的 Turso 数据库。
- 将步骤 1 中的数据库转储导入到新的 Turso DB 中。
- 确认你的项目连接到新数据库后,你就可以安全地从 Astro Studio 中删除该项目了。