Drizzle 查询
Drizzle ORM 旨在成为 SQL 之上的一个薄型类型层。
我们真心相信我们设计了从 TypeScript 操作 SQL 数据库的最佳方法,现在是时候使其更出色了。
关系查询旨在为您提供出色的开发者体验,
以便从 SQL 数据库中查询嵌套的关系数据,避免多个连接和复杂的数据映射。
它是现有模式定义和查询构建器的扩展。
您可以根据自己的需求选择使用它。
我们确保为您提供最优秀的开发者体验和性能。
⚠️ 如果您在多个文件中声明 SQL 模式,您可以这样做:
index.ts
schema1.ts
schema2.ts
模式
Drizzle 关系查询总是生成一个 SQL 语句在数据库上运行,并且有一些注意事项。
为了对每种数据库提供最佳支持,我们引入了 modes
。
Drizzle 关系查询在底层使用子查询的侧向连接,目前 PlanetScale 不支持它们。
当使用 mysql2 驱动程序与常规 MySQL 数据库时 — 你应该指定 mode: "default"
,
当使用 mysql2 驱动程序与 PlanetScale 时 — 你需要指定 mode: "planetscale"
。
查询
关系查询是 Drizzle 原始 查询构建器 的一个扩展。
您需要在 drizzle()
初始化时提供来自您的模式文件/文件的所有 tables
和 relations
,
然后只需使用 db.query
API。
Drizzle 提供 .findMany()
和 .findFirst()
API。
查找多个
查找第一个
.findFirst()
会在查询中添加 limit 1
。
包括关系
With
操作符允许您从多个相关表中组合数据并正确聚合结果。
获取所有带评论的帖子:
获取第一个带评论的帖子:
您可以根据需要链式调用嵌套的 with 语句。
对于任何嵌套的 with
查询,Drizzle 将使用 Core Type API 推断类型。
获取所有用户及其帖子。每个帖子应包含评论列表:
部分字段选择
columns
参数允许您包含或省略要从数据库中获取的列。
Drizzle 在查询级别执行部分选择,没有额外数据被从数据库中传输。
请记住 Drizzle 输出的是单个 SQL 语句。
仅获取带有 id
、content
的所有帖子,并包括 comments
:
获取没有 content
的所有帖子:
当同时存在 true
和 false
的选择选项时,所有 false
的选项将被忽略。
如果您包含 name
字段并排除 id
字段,则 id
的排除将是多余的,
因为除了 name
的所有字段都将被排除。
在同一查询中排除和包含字段:
仅包含来自嵌套关系的列:
嵌套部分字段选择
就像 部分选择
一样,您可以包含或排除嵌套关系的列:
选择过滤器
就像在我们的 SQL 风格查询构建器中一样,关系查询 API 允许您定义过滤器和条件,
使用我们 运算符
的列表。
您可以从 drizzle-orm
导入它们,或使用回调语法直接使用:
寻找 id=1
并且在特定日期之前创建的评论的帖子:
限制与偏移
Drizzle ORM 为查询和嵌套实体提供 limit
和 offset
API。
寻找 5 个帖子:
查找帖子并最多获取 3 条评论:
IMPORTANT
查找帖子并获取第 5 到第 10 个帖子的评论:
排序
Drizzle 为关系查询构建器提供了排序 API。
您可以使用相同的排序 核心 API
或在没有导入的情况下使用回调中的 order by
运算符。
按 asc
+ desc
排序:
包括自定义字段
关系查询 API 允许您添加自定义附加字段。
这在您需要检索数据并对其应用附加函数时非常有用。
IMPORTANT
目前在 extras
中不支持聚合,请使用 核心查询
来处理。
lowerName
作为键将包括在返回对象的所有字段中。
IMPORTANT
您必须显式指定 .as("<name_for_column>")
要检索所有用户及其组,但包括 fullName 字段(它是 firstName 和 lastName 的连接),
您可以使用以下查询与 Drizzle 关系查询构建器。
要检索所有带评论的帖子并添加一个额外字段以计算帖子内容和每条评论内容的大小:
预编译语句
预编译语句旨在大幅提高查询性能 — 请查看此处.
在本节中,您可以学习如何定义占位符以及如何使用
Drizzle 关系查询构建器执行预编译语句。
where
中的占位符
limit
中的占位符
offset
中的占位符
多个占位符