yeluochengshang 2013-05-24 10:29
浏览 1341
已采纳

多表关联查询效率就很低,有没有只改SQL的优化方案?

简化模型如下:
[code="sql"]
select * from t,ut,u
where t.tid = ut.tid
and ut.uid = u.uid
[/code]
其中t表和ut表的数据量都在300W的样子,u表的数据量200条左右
查询时间在10秒左右

有没有什么好的优化方案?只从数据库这一层来做优化的
(历史原因:任SB设计人员非要搞了一个中间表ut,实际上在t表中多搞一个uid的字段就好了,然后可以废除ut表,但是修改模型的话代价太大了)

  • 写回答

10条回答 默认 最新

  • zyn010101 2013-05-24 10:40
    关注

    一下子查询出来这么多数据时间当然久了,试着查询出100条记录试试,如果时间仍然比较久,可以考虑触发器:新建一张表,存三张表所有的字段,ut新增时的触发器往新表插入数据,删除的时候删除新表数据,t表和u表修改的时候修改新表,查询的时候查询新表(只改查询sql),其他增删改逻辑都不变。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(9条)

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog