- 获得原始结果
获得原始结果
使用选择查询构建器可以获得两种类型的结果:entities 和 raw results。大多数情况下,你只需要从数据库中选择真实实体,例如 users。为此,你可以使用getOne
和getMany
。但是,有时需要选择特定数据,例如 sum of all user photos。这些数据不是实体,它被称为原始数据。要获取原始数据,请使用getRawOne
和getRawMany
。例如:
const { sum } = await getRepository(User)
.createQueryBuilder("user")
.select("SUM(user.photosCount)", "sum")
.where("user.id = :id", { id: 1 })
.getRawOne();
const photosSums = await getRepository(User)
.createQueryBuilder("user")
.select("user.id")
.addSelect("SUM(user.photosCount)", "sum")
.where("user.id = :id", { id: 1 })
.getRawMany();
// 结果将会像这样: [{ id: 1, sum: 25 }, { id: 2, sum: 13 }, ...]