Find 选项

    • select - 表示必须选择对象的哪些属性
    • relations - 关系需要加载主体。 也可以加载子关系(join 和 leftJoinAndSelect 的简写)
    1. userRepository.find({ relations: ["profile", "photos", "videos"] });
    2. userRepository.find({ relations: ["profile", "photos", "videos", "videos.video_attributes"] });
    • join - 需要为实体执行联接,扩展版对的”relations”。
    1. userRepository.find({
    2. join: {
    3. alias: "user",
    4. leftJoinAndSelect: {
    5. profile: "user.profile",
    6. photo: "user.photos",
    7. video: "user.videos"
    8. }
    9. }
    10. });
    • where -查询实体的简单条件。
    1. userRepository.find({ where: { firstName: "Timber", lastName: "Saw" } });

    查询嵌入实体列应该根据定义它的层次结构来完成。 例:

    1. userRepository.find({ where: { name: { first: "Timber", last: "Saw" } } });

    使用 OR 运算符查询:

    1. userRepository.find({
    2. where: [{ firstName: "Timber", lastName: "Saw" }, { firstName: "Stan", lastName: "Lee" }]
    3. });

    将执行以下查询:

    1. SELECT * FROM "user" WHERE ("firstName" = 'Timber' AND "lastName" = 'Saw') OR ("firstName" = 'Stan' AND "lastName" = 'Lee')
    • order - 选择排序
    1. userRepository.find({
    2. order: {
    3. name: "ASC",
    4. id: "DESC"
    5. }
    6. });

    返回多个实体的find方法(findfindAndCountfindByIds),同时也接受以下选项:

    • skip - 偏移(分页)
    1. userRepository.find({
    2. skip: 5
    3. });
    • take - limit (分页) - 得到的最大实体数。
    1. userRepository.find({
    2. take: 10
    3. });

    ** 如果你正在使用带有 MSSQL 的 typeorm,并且想要使用takelimit,你必须正确使用 order,否则将会收到以下错误:'FETCH语句中NEXT选项的使用无效。'

    1. userRepository.find({
    2. order: {
    3. columnName: "ASC"
    4. },
    5. skip: 0,
    6. take: 10
    7. });
    • cache - 启用或禁用查询结果缓存。 有关更多信息和选项,请参见caching
    1. cache: true
    2. });

    例如:

    find 选项的完整示例:

    1. userRepository.find({
    2. select: ["firstName", "lastName"],
    3. relations: ["profile", "photos", "videos"],
    4. where: {
    5. firstName: "Timber",
    6. lastName: "Saw"
    7. },
    8. order: {
    9. name: "ASC",
    10. id: "DESC"
    11. },
    12. skip: 5,
    13. take: 10,
    14. cache: true
    15. });

    进阶选项

    • Not
    1. import { Not } from "typeorm";
    2. const loadedPosts = await connection.getRepository(Post).find({
    3. title: Not("About #1")
    4. });

    将执行以下查询:

    1. SELECT * FROM "post" WHERE "title" != 'About #1'
    • LessThan
    1. import { LessThan } from "typeorm";
    2. const loadedPosts = await connection.getRepository(Post).find({
    3. likes: LessThan(10)
    4. });

    将执行以下查询:

    1. SELECT * FROM "post" WHERE "likes" < 10
    • LessThanOrEqual
    1. import { LessThanOrEqual } from "typeorm";
    2. const loadedPosts = await connection.getRepository(Post).find({
    3. likes: LessThanOrEqual(10)
    4. });

    将执行以下查询:

    1. SELECT * FROM "post" WHERE "likes" <= 10
    • MoreThan
    1. import { MoreThan } from "typeorm";
    2. const loadedPosts = await connection.getRepository(Post).find({
    3. likes: MoreThan(10)
    4. });

    将执行以下查询:

    1. SELECT * FROM "post" WHERE "likes" > 10
    • MoreThanOrEqual
    1. import { MoreThanOrEqual } from "typeorm";
    2. const loadedPosts = await connection.getRepository(Post).find({
    3. likes: MoreThanOrEqual(10)

    将执行以下查询:

    1. SELECT * FROM "post" WHERE "likes" >= 10
    1. import { Equal } from "typeorm";
    2. const loadedPosts = await connection.getRepository(Post).find({
    3. title: Equal("About #2")
    4. });

    将执行以下查询:

    1. SELECT * FROM "post" WHERE "title" = 'About #2'
    • Like

    将执行以下查询:

    1. SELECT * FROM "post" WHERE "title" LIKE '%out #%'
    • Between
    1. import { Between } from "typeorm";
    2. const loadedPosts = await connection.getRepository(Post).find({
    3. likes: Between(1, 10)
    4. });
    1. SELECT * FROM "post" WHERE "likes" BETWEEN 1 AND 10
    • In
    1. import { In } from "typeorm";
    2. const loadedPosts = await connection.getRepository(Post).find({
    3. title: In(["About #2", "About #3"])
    4. });

    将执行以下查询:

    1. SELECT * FROM "post" WHERE "title" IN ('About #2','About #3')
    • Any
    1. import { Any } from "typeorm";
    2. const loadedPosts = await connection.getRepository(Post).find({
    3. title: Any(["About #2", "About #3"])
    4. });

    将执行以下查询: (Postgres notation):

    1. SELECT * FROM "post" WHERE "title" = ANY(['About #2','About #3'])
    • IsNull
    1. import { IsNull } from "typeorm";
    2. const loadedPosts = await connection.getRepository(Post).find({
    3. title: IsNull()
    4. });

    将执行以下查询:

    1. SELECT * FROM "post" WHERE "title" IS NULL
    • Raw
    1. import { Raw } from "typeorm";
    2. const loadedPosts = await connection.getRepository(Post).find({
    3. likes: Raw("1 + likes = 4")
    4. });

    将执行以下查询:

    1. SELECT * FROM "post" WHERE 1 + "likes" = 4

    你还可以将这些运算符与Not运算符组合使用:

    1. import { Not, MoreThan, Equal } from "typeorm";
    2. const loadedPosts = await connection.getRepository(Post).find({
    3. likes: Not(MoreThan(10)),
    4. title: Not(Equal("About #2"))
    5. });

    将执行以下查询: