使用QueryBuilder
获取值
要从数据库中获取单个结果,例如通过 id 或 name 获取用户,必须使用getOne
:
const timber = await getRepository(User)
.createQueryBuilder("user")
.where("user.id = :id OR user.name = :name", { id: 1, name: "Timber" })
.getOne();
要从数据库中获取多个结果,例如,要从数据库中获取所有用户,请使用getMany
:
const users = await getRepository(User)
.createQueryBuilder("user")
.getMany();
使用查询构建器查询可以获得两种类型的结果: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 }, ...]