[ 
https://issues.apache.org/jira/browse/IGNITE-6202?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Vladimir Ozerov updated IGNITE-6202:
------------------------------------
    Labels: performance sql-engine  (was: performance)

> SQL: support hash join
> ----------------------
>
>                 Key: IGNITE-6202
>                 URL: https://issues.apache.org/jira/browse/IGNITE-6202
>             Project: Ignite
>          Issue Type: Task
>          Components: sql
>    Affects Versions: 2.1
>            Reporter: Vladimir Ozerov
>            Priority: Major
>              Labels: performance, sql-engine
>
> Justification is the same as for IGNITE-6201 (merge joins). If join is 
> equijoin, and participating attributes are not sorted in advance, then 
> instead of executing nested loops, we can do the following:
> 1) Get the table with smaller number of entries
> 2) Build a hash table from target attribute to the list of matching entries
> 3) Iterate over larger table and perform lookup into hash table
> Note that this operation might be memory-intensive in case smaller table is 
> large enough still. For this reason we should provide a mechanism to avoid 
> out-of-memory errors. Let's avoid spilling to disk in the first iteration, 
> and try to set a kind of hard limit on how much data can be kept in memory. 
> If we see that this limit cannot be satisfied, then fallback to nested loops.



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)

Reply via email to