使用原始查询比较同一表中的列
比较同一表中的不同列是开发人员经常遇到的场景。一些示例包括比较同一表中的两个数值或比较同一表中的两个日期。有一个关于此的现有 GitHub 问题。
警告
从 4.3.0 版本开始,您无需使用原始查询来比较同一表中的列。您可以使用 <model>.fields
属性来比较列。
以下信息是为了与 4.3.0 之前的 Prisma ORM 版本向后兼容而保留的。
解决方法
可以使用原始查询来实现比较同一表中两列的值。
比较数值
信息
从 4.3.0 版本开始,您无需使用原始查询来比较同一表中的列。您可以使用 <model>.fields
属性来比较列。了解更多
比较不同列的值的一个用例是检索评论数多于点赞数的帖子;在这种情况下,您需要比较 commentsCount
和 likesCount
的值。
model Post {
id Int @id @default(autoincrement())
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
title String
content String?
published Boolean @default(false)
author User @relation(fields: [authorId], references: [id])
authorId Int
likesCount Int
commentsCount Int
}
查询(取决于哪个数据库)可能如下所示
PostgreSQL / CockroachDB
import { PrismaClient } from '@prisma/client'
const prisma = new PrismaClient()
async function initiateNumbersComparisonRawQuery() {
const response =
await prisma.$queryRaw`SELECT * FROM "public"."Post" WHERE "likesCount" < "commentsCount";`
console.log(response)
}
await initiateNumbersComparisonRawQuery()
MySQL
import { PrismaClient } from '@prisma/client'
const prisma = new PrismaClient()
async function initiateNumbersComparisonRawQuery() {
const response =
await prisma.$queryRaw`SELECT * FROM \`public\`.\`Post\` WHERE \`likesCount\` < \`commentsCount\`;`
console.log(response)
}
await initiateNumbersComparisonRawQuery()
Sqlite
import { PrismaClient } from '@prisma/client'
const prisma = new PrismaClient()
async function initiateNumbersComparisonRawQuery() {
const response =
await prisma.$queryRaw`SELECT * FROM "Post" WHERE "likesCount" < "commentsCount";`
console.log(response)
}
await initiateNumbersComparisonRawQuery()
运行以上查询(取决于数据库)将筛选出点赞数少于评论数的帖子。
查询响应
;[
{
id: 1,
createdAt: '2022-03-03T12:08:11.421+00:00',
updatedAt: '2022-03-03T12:08:11.422+00:00',
title: 'Hello World',
content: 'This is my first post',
published: false,
authorId: 1,
likesCount: 50,
commentsCount: 100,
},
]
比较日期值
信息
从 4.3.0 版本开始,您无需使用原始查询来比较同一表中的列。您可以使用 <model>.fields
属性来比较列。了解更多
同样,如果您需要比较日期,您也可以使用原始查询来实现相同的目的。
例如,一个用例可能是获取所有在截止日期之后完成的项目。
model Project {
id Int @id @default(autoincrement())
title String
author User @relation(fields: [authorId], references: [id])
authorId Int
dueDate DateTime
completedDate DateTime
createdAt DateTime @default(now())
}
查询(取决于数据库)可能如下所示
PostgreSQL / CockroachDB
import { PrismaClient } from '@prisma/client'
const prisma = new PrismaClient()
async function initiateDatesComparisonRawQuery() {
const response =
await prisma.$queryRaw`SELECT * FROM "public"."Project" WHERE "completedDate" > "dueDate";`
console.log(response)
}
await initiateDatesComparisonRawQuery()
MySQL
import { PrismaClient } from '@prisma/client'
const prisma = new PrismaClient()
async function initiateDatesComparisonRawQuery() {
const response =
await prisma.$queryRaw`SELECT * FROM \`public\`.\`Project\` WHERE \`completedDate\` > \`dueDate\`;`
console.log(response)
}
await initiateDatesComparisonRawQuery()
Sqlite
import { PrismaClient } from '@prisma/client'
const prisma = new PrismaClient()
async function initiateDatesComparisonRawQuery() {
const response =
await prisma.$queryRaw`SELECT * FROM "Project" WHERE "completedDate" > "dueDate";`
console.log(response)
}
await initiateDatesComparisonRawQuery()
运行上述查询将获取 completedDate
在 dueDate
之后的项目。
查询响应
;[
{
id: 1,
title: 'Project 1',
authorId: 1,
dueDate: '2022-03-10T00:00:00+00:00',
completedDate: '2022-03-12T00:00:00+00:00',
createdAt: '2022-03-03T12:08:11.421+00:00',
},
]