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

多表关联查询效率就很低,有没有只改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条)

报告相同问题?