- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
为不好的标题道歉,努力想另一个。
目前,我有 2 个表,publication
和 publicationStatus
。
出版物看起来像这样:
{
"id": "ckyil950d00027v2str5ljo7h",
"url_slug": "ckyil950e00037v2s4mqxvaho",
"type": "PEER_REVIEW",
"title": "Intersting review",
"content": "Content is optional at this stage",
"doi": "1093/ajae/aaq063",
"createdBy": "test-user-1",
"createdAt": "2022-01-17T11:12:50.845Z",
"updatedAt": "2022-01-17T11:12:50.847Z",
"publicationStatus": [
{
"status": "LIVE",
"createdAt": "2022-01-19T11:12:50.846Z",
"id": "ckyil950e00047v2sx4urbfte"
},
{
"status": "DRAFT",
"createdAt": "2022-01-17T11:12:50.846Z",
"id": "ckyil950e00047v2sx4urbfth"
}
],
"user": {
"id": "test-user-1",
"firstName": "Test",
"lastName": "User 1"
}
}
其中 publication
与 publicationStatus
具有一对多关系。
我需要做的是一个find
查询,如果latest publicationStatus
,它只返回一个publication
对于该 publication
,status
为 LIVE
。
有什么想法吗?
编辑:我能想到的最接近的是这个伪代码:
await prisma.publication.findFirst({
where: {
id,
publicationStatus: {
where: {
status: 'LIVE'
},
take: 1,
orderBy: {
createdAt: 'desc'
}
},
}
});
此代码不有效,但演示了我正在努力实现的目标。
最佳答案
不幸的是,我认为目前无法直接使用 Prisma 查询来完成您希望的操作。不过,我可以建议两种可能的解决方法:
方法 1: 获取最新的 publicationStatus
以及 publication
并检查节点内的 status
申请。
这是查询的样子:
let publication = await prisma.publication.findFirst({
where: {
id
},
include: {
publicationStatus: {
orderBy: {
createdAt: 'desc'
},
take: 1
}
}
});
// check publication.publicationStatus[0].status and handle appropriately
方法 2:使用 queryRaw
编写原始 SQL 查询方法。
对于单个出版物,我认为使用方法 1 会更容易。但是,如果您想返回所有 LIVE 出版物(您在评论中提到了这一点),方法的性能特征1 可能是不受欢迎的。
关于Prisma,根据表2中最新的外键从表1中选择行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70748250/
我想更改 prisma 文件夹的名称和位置。目前它叫做 prisma,它位于我的 nextjs 项目的根文件夹中。我想将它命名为 db 并将其放在 src 文件夹中。那可能吗?如果是,怎么办? 最佳答
我正在评估 Prisma,我是一个完整的菜鸟...... 我正在使用 Postgresql 我有以下模型定义 model Sth { id Int @d
我正在使用 Prisma 我有一个要搜索的 postgres 表,只查找匹配 where (id 和 accessKey) 或 (id 和 ownerId) 的记录 如果 accessKey 或 ow
上面一个是我在Vercel上部署MongoDB(Atlas URL)后端和Prisma作为ORM时遇到的问题。。我观察到部署时缺少@prisma/client实例。我已经创建了单独的文件Prisma对
上面一个是我在Vercel上部署MongoDB(Atlas URL)后端和Prisma作为ORM时遇到的问题。。我观察到部署时缺少@prisma/client实例。我已经创建了单独的文件Prisma对
我是 Prisma 的新手,虽然到目前为止它非常容易上手,但我遇到了一个我似乎无法找到好的答案的问题。我已经阅读了 docs about relation queries ,但据我了解,Prisma
我找不到任何示例来说明如何使用整数执行此操作,并且我的选项不起作用( 我的表包含 2 列整数,我需要使用 prisma 原始查询向其中添加多行。 如果我只添加 1 行并使用 Prisma.join()
以 Prisma 文档中的架构为例,我想查询 Users 以查找没有任何 posts 的任何用户。我可以像这样破解它,以便它检索所有帖子的 ID 都不大于 0 的每个用户,但这不是很优雅。有更好的方法
这是我的 datamodel.prisma 文件的相关部分。 type Driver { id: ID! @unique zones: [Zone!] @relation(name: "Dri
我正在使用 Prisma 1.9 和 Postgres。 如何重置所有内容?我已经尝试过 prisma local nuke ,但此命令会添加 MySQL 容器(以某种方式),然后抛出端口 4466
以 Prisma 文档中的架构为例,我想查询 Users 以查找没有任何 posts 的任何用户。我可以像这样破解它,以便它检索所有帖子的 ID 都不大于 0 的每个用户,但这不是很优雅。有更好的方法
这是我的 datamodel.prisma 文件的相关部分。 type Driver { id: ID! @unique zones: [Zone!] @relation(name: "Dri
我有以下查询,它给出了所有帖子和所有评论的计数。现在,我想计算已批准字段设置为 true 的帖子的所有评论数。我似乎无法弄清楚这一点。 prisma.post.findMany({ inclu
我发现您现在使用的是 MySQL 和 PostgreSQL,它们支持地理空间类型,我该如何对我的 prisma 执行地理空间查询。 假设我想获取纽约市附近的所有事件? 最佳答案 我使用 Prisma
运行prisma init 不会生成文件。它不会生成下面的 3 个文件。 datamodel.graphql docker-compose.yml 棱镜.yml 最终收到此错误:- { "e
我开始使用这个惊人的工具包,并注意到当我生成迁移文件时,Prisma 还会在新模式旁边创建一个 README 文件。该文件的副标题中恰好有我的个人姓名:This migration has been
我是 Prisma 和 Nodejs 的新手 我不小心创建了许多 Prisma Client 实例,这些实例一直显示警告 warn(prisma-client) 已经有 10 个 Prisma Cli
在 this example ,我们看到: 名称字符串? 不 💯 ? 在这里表示什么...... 最佳答案 这意味着在数据库中。该字段可以为空。这是可选的。 关于prisma-graphql - 定
我正在尝试计算 Prisma2 中的 self 关系(关注者)(使用 PostgreSQL) 型号: model User { id String @id @default(cui
嗨 - 我一直在关注 GraphQL/Prisma 教程 ( https://www.howtographql.com/graphql-js/6-authentication/ ),我想知道为什么要在
我是一名优秀的程序员,十分优秀!