如何解决Prisma 获取所有树
我正在使用 Prisma 新项目。我有类别递归关系:
model Category {
id Int @id @default(autoincrement())
name String
children Category[] @relation("CategoryToCategory")
parentId Int?
parent Category? @relation(fields: [parentId],references: [id])
}
这种关系很好用,但是为了获得所有孩子的所有类别(完整的树,不仅是 1 级),我不知道 Prisma 是否可行?这通常称为急切加载。
有了这个请求,我只得到第一个孩子,但我想要所有的树,你知道这是否可能吗?
const allCategories = await db.category.findMany({
include: {
parent: true,// return only first level
children: true,// return only first level
},})
谢谢!
解决方法
在这种情况下,您需要在 include
中明确指定您需要多少级,因为 Prisma 不支持 fetching recursive relations。
如果您使用 Postgres,另一种选择是使用递归 CTE(通过 with
)。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。