home clear 64x64
en blue 200x116 de orange 200x116 info letter User
suche 36x36
Latest versionsfixlist
11.1.0.7 FixList
10.5.0.9 FixList
10.1.0.6 FixList
9.8.0.5 FixList
9.7.0.11 FixList
9.5.0.10 FixList
9.1.0.12 FixList
Have problems? - contact us.
Register for free anmeldung-x26
Contact form kontakt-x26

DB2 - Problem description

Problem IC79025 Status: Closed

QUERY PERFORMANCE MAY BE POOR FOR A JOIN BETWEEN A UNION AND THE GROUP BY
OF A VALUES OR UNNEST TABLE FUNCTION

product:
DB2 FOR LUW / DB2FORLUW / 970 - DB2
Problem description:
Queries may experience poor performance when the query contains 
a join between: 
1) a sub-select comprised of a VALUES or UNNEST table function 
and a GROUP BY clause 
2) a view, common-table-expression or nested-table-expression 
containing a UNION or UNION ALL operation 
 
The GROUP BY sub-select is not pushed below the UNION ALL to 
provide filtering on each arm of the UNION. 
 
The following examples show this query pattern: 
 
1) A UNION ALL view joined with a VALUES table function GROUP BY 
 
CREATE VIEW employees as ( 
                SELECT * FROM employees_CA WHERE country = 'CA' 
                 UNION ALL 
                SELECT * FROM employees_US where country = 'US' 
       ); 
 
SELECT empid, lastname, deptno 
  FROM ( SELECT deptid 
           FROM table( values ?,?,?,?,?,?,?,?,?,?) as 
tmp(deptid) 
           GROUP BY deptid 
       ) as d, employees as e 
 WHERE e.deptno = d.deptid 
 
2) A UNION ALL common-table-expression joined with an UNNEST 
table-function GROUP BY 
 
CREATE TYPE intArray as INTEGER ARRAY[100]; 
CREATE VARIABLE deptid_arr intArray; 
 
WITH employees as ( 
                SELECT * FROM employees_CA WHERE country = 'CA' 
                 UNION ALL 
                SELECT * FROM employees_US where country = 'US' 
       ) 
SELECT empid, lastname, deptno 
  FROM ( SELECT deptid 
           FROM table( UNNESTT(deptid_arr) ) as tmp(deptid) 
           GROUP BY deptid 
       ) as d, employees as e 
 WHERE e.deptno = d.deptid
Problem Summary:
**************************************************************** 
* USERS AFFECTED:                                              * 
* ALL                                                          * 
**************************************************************** 
* PROBLEM DESCRIPTION:                                         * 
* .                                                            * 
**************************************************************** 
* RECOMMENDATION:                                              * 
* Apply version 9.7 Fix Pack 5 on the database server.         * 
****************************************************************
Local Fix:
Rewrite the query to manually push the join to VALUES or UNNEST 
GROUP BY into each arm of the UNION ALL. For example 
 
WITH d(deptid) as ( SELECT deptid 
                      FROM table( UNNESTT(deptid_arr) ) as 
tmp(deptid) 
                      GROUP BY deptid 
                  ) 
SELECT empid, lastname, deptno 
  FROM employees_CA as e, d 
 WHERE country  = 'CA' 
   AND E.DEPTNO = D.DEPTID 
 UNION ALL 
SELECT empid, lastname, deptno 
  FROM employees_US as e, d 
 where country  = 'US' 
   AND E.DEPTNO = D.DEPTID;
available fix packs:
DB2 Version 9.7 Fix Pack 5 for Linux, UNIX, and Windows
DB2 Version 9.7 Fix Pack 6 for Linux, UNIX, and Windows
DB2 Version 9.7 Fix Pack 7 for Linux, UNIX, and Windows
DB2 Version 9.7 Fix Pack 8 for Linux, UNIX, and Windows
DB2 Version 9.7 Fix Pack 9 for Linux, UNIX, and Windows
DB2 Version 9.7 Fix Pack 9a for Linux, UNIX, and Windows
DB2 Version 9.7 Fix Pack 10 for Linux, UNIX, and Windows

Solution
Problem was first fixed in Version 9.7 Fix Pack 5
Workaround
not known / see Local fix
Timestamps
Date  - problem reported    :
Date  - problem closed      :
Date  - last modified       :
03.10.2011
19.12.2011
19.12.2011
Problem solved at the following versions (IBM BugInfos)
9.7.FP5
Problem solved according to the fixlist(s) of the following version(s)
9.7.0.5 FixList