栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

SQL:速度提高-cond1或cond2上的左联接

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

SQL:速度提高-cond1或cond2上的左联接

如果人们的建议没有显着提高速度,则您的真正问题很可能是,针对两种可能的联接条件的最佳查询计划是不同的。对于这种情况,您可能要执行两个查询并以某种方式合并结果。这可能会使您的查询变得非常丑陋。

我在这种情况下使用的一个晦涩的技巧是在UNIOn ALL查询的基础上执行GROUP BY。这个主意看起来像这样:

SELECt a_field1, a_field2, ...  MAX(b_field1) as b_field1, MAX(b_field2) as b_field2, ...FROM (      SELECt a.field_1 as a_field1, ..., b.field1 as b_field1, ...      FROM current_tbl a        LEFT JOIN import_tbl b          ON a.user_id = b.user_id    UNIOn ALL      SELECt a.field_1 as a_field1, ..., b.field1 as b_field1, ...      FROM current_tbl a        LEFT JOIN import_tbl b          ON a.f_name = b.f_name AND a.l_name = b.l_name  )GROUP BY a_field1, a_field2, ...

现在,数据库可以使用最有效的计划来执行两个联接中的每个联接。

(警告这种方法的缺点。如果current_tbl中的行与import_tbl中的多行联接,那么您将以非常奇怪的方式合并数据。)

附带的随机性能提示。除非您有理由相信可能存在重复的行,否则请避免使用DISTINCT。它强制使用隐式的GROUP BY,这可能会很昂贵。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/431559.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号