读书人

怎么优化多表联合查询速度

发布时间: 2013-08-16 14:29:57 作者: rapoo

如何优化多表联合查询速度?
一个update联合了10个表,平均每个表数据大约2万行,关联的字段已经建立了索引,但是查询依旧较慢,时间为62秒。上面要求优化到5秒以下,我就想骂人:我认为,数据量在50万,甚至百万以下的系统,但凡查询需要关联6个表以上的数据库设计,(也可能涉及到软件设计)都是狗屎。更何况是逻辑简单的小系统。

但我无能为力,也可能是孤陋寡闻,无论如何,只能按时完成任务,求高手指教优化方法!

查找出比较耗时的节点,如果不是索引查询(index seek,注意(index scan)不是索引查询,依旧是全表遍历(table scan)!),那么就先针对关联的字段建立索引.如果已是索引查询,参考下图:
怎么优化多表联合查询速度

如果这样还没起到效果,则可能是你要查询的结果数据量比较大,建议参考caozhy 版主所说的分表分库、使用数据缓存等。

读书人网 >C#

热点推荐