开发者社区 问答 正文

一个业务实现,有关sql查询优化

A(A.id ,B.id , C.id)
B ( B.id)
C. (C.id)
要求:
1.查询返回A(过滤过的)和B表的数据,
2.A 表的数据是where 条件 C.id 在C表中经过where条件过滤后的 C.id 列表

  1. 不要用表连接查询,诸如 left join 之类,
  2. ,持久层用的mybatis

5.如果先把C表id查出来然后作为参数传递,在xml中用foreach 循环,就要用到 in, 索引失效。。性能上会不会受影响?

6.能否给一个性能最优的解决方案,就针对这个业务需求实现

A 表数据会慢慢变大,由于要考虑性能,什么表连接查询我都放弃了。。但是想不到一个好办法。。

展开
收起
爵霸 2016-06-02 11:41:52 2924 分享 版权
1 条回答
写回答
取消 提交回答
  • 换postgresql吧。这样才能left join。

    2019-07-17 19:24:30
    赞同 展开评论