首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >TypeORM子查询

TypeORM子查询
EN

Stack Overflow用户
提问于 2018-11-30 16:03:59
回答 1查看 30.9K关注 0票数 12

基于typeORM docs上的使用子查询,这里解释了如何创建子查询。示例:

代码语言:javascript
运行
复制
const qb = await getRepository(Post).createQueryBuilder("post");
const posts = qb
    .where("post.title IN " + qb.subQuery().select("user.name").from(User, "user").where("user.registered = :registered").getQuery())
    .setParameter("registered", true)
    .getMany();

但是对于SQL应该是什么,并没有等价物。

假设我有一个包含如下所示的子查询的查询:

代码语言:javascript
运行
复制
SELECT a, TO_CHAR (MAX (jointable.f), 'MON YYYY') as f,
   t3.c, t3.d, t1.e
FROM table1 t1 
LEFT JOIN table2 t2 ON t2.e = t1.e
JOIN table3 t3 ON t3.d = t2.d
JOIN
 (SELECT f, t4.g, t5.e, t6.h
   FROM table4 t4 
   JOIN table5 t5 ON t4.g = t5.g
   JOIN table6 t6 ON t6.g = t4.g
   AND (t6.i = 2
        OR (t6.i = 1 AND j = 1)
       )
     WHERE t4.k = 4
     ) jointable ON t1.e = jointable.e
WHERE jointable.h = :h
AND(:d = 3 OR 
    t3."d" = :d
   )
GROUP BY a, t3.c, t3.d, t1.e
ORDER BY a ASC

对于上面的typeORM查询,我应该如何使用SQL查询构建器函数?

假设我已经创建了与上面查询中使用的所有表相关的实体。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-11-30 19:15:47

我希望这个答案能帮助其他人使用TypeORM子查询。

代码语言:javascript
运行
复制
const subquery = await getManager()
    .createQueryBuilder(table4, 't4')
    .select('"t4".f')
    .addSelect('"t4".g')
    .addSelect('"t5".e')
    .addSelect('"t6".h')
    .innerJoin(table5, 't5', '"t4".g = "t5".g')
    .innerJoin(table6, 't6', '"t6".g = "t4".g')
    .where('"t4".k = 4 AND ("t6".i = 2 OR ("t6".i = 1 AND "t6".j = 1))');

  model = await getManager()
    .createQueryBuilder(table1, 't1')
    .select('"t1".a')
    .addSelect("TO_CHAR (MAX (jointable.f), 'MON YYYY')", 'f')
    .addSelect('"t3".c')
    .addSelect('"t3".d')
    .addSelect('"t1".e')
    .leftJoin('table2', 't2', '"t2".e = "t1".e')
    .innerJoin(table3, 't3', '"t3".d = "t2".d')
    .innerJoin('('+subquery.getQuery()+')', 'jointable', '"t1".e = jointable.e')
    .where('jointable.h = :h AND (:d = 3 OR "t3".d = :d)',
      { h: h, d: d })
    .groupBy('"t1".a, "t3".c, "t3".d, "t1".e')
    .orderBy('"t1".a', 'ASC')
    .getRawMany();

我使用'('+subquery.getQuery()+')'来获得子查询select查询,相当于

(选择f、t4.g、t5.e、t6.h....

.

……)t1.e上的jointable =jointable

根据我的理解:

  • .select是SQL中的select的等价物。您还可以添加(as in SQL).

aliases

  • .addSelect类似于, in select

票数 23
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53553523

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档