码迷,mamicode.com
首页 > 其他好文 > 详细

Firebird hash join

时间:2018-07-14 17:40:57      阅读:170      评论:0      收藏:0      [点我收藏+]

标签:默认   index   class   优化器   技术分享   nested   中大型   where   firebird   

Firebird 现可支持哈希连接(hash join),各中大型数据库,哈希连接已成为平常,相对于循环嵌套连接(Nested Loop Join),在数据量较大的情况下,哈希连接性能较好。

由于 Firebird 的sql查询优化器做的不是很好,需要使用者显式的指定是否使用hash join,否则默认就用循环嵌套连接。

在sql语句上可以这样标示,来使用hash join:

1 select * from  b_inbound_puton a
2     join b_inbound_detail b on a.inbound_dt_id +0 = b.id +0
3     join b_inbound c on b.inbound_id +0 = c.id +0
4 where c.id = 0

即,在连接的字段上用 +0 来指定hash join。

执行计划:

 1 Select Expression
 2     -> Filter
 3         -> Hash Join (inner)
 4             -> Filter
 5                 -> Hash Join (inner)
 6                     -> Filter
 7                         -> Table "B_INBOUND" as "C" Access By ID
 8                             -> Bitmap
 9                                 -> Index "PK_B_INBOUND" Unique Scan
10                     -> Record Buffer (record length: 321)
11                         -> Table "B_INBOUND_DETAIL" as "B" Full Scan
12             -> Record Buffer (record length: 313)
13                 -> Table "B_INBOUND_PUTON" as "A" Full Scan

 PLAN HASH (HASH (C INDEX (PK_B_INBOUND), B NATURAL), A NATURAL) 

技术分享图片

 

Firebird hash join

标签:默认   index   class   优化器   技术分享   nested   中大型   where   firebird   

原文地址:https://www.cnblogs.com/jonney-wang/p/9310275.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!