473,785 Members | 2,255 Online
Bytes | Software Development & Data Engineering Community
+ Post

Home Posts Topics Members FAQ

problem with MQT

Hi

I havent used MQT before. Read the online tips and tutorials but none
seems to give any hint for my problem.

I have a base table (base_table) as:

st varchar(25) default 'my_null'
dt timestamp default
'1900-01-01-00.00.00.00000'
num integer default -999999
My requirement is that for any of these default value in base table,
null should be populated in the materialized view.
I tried the following to create a mqt:
CREATE TABLE OUT_table AS (SELECT
CASE DT WHEN
'1900-01-01-00.00.00.000000 ' THEN null ELSE DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST FROM
base_table)
DATA INITIALLY DEFERRED REFRESH DEFERRED

Then tried creating the staging table:

create table m_out_table for out_table propagate
immediate

This gave me error: SQL20058N The fullselect specified for the
materialized query table "test.OUT_table " is not valid. Reason code =
"7
Can, the thing that I am trying to do (put null values for 'my_null'
etc), be done? If yes, how?

Thanks.
Jan 7 '08 #1
10 4405
On Jan 7, 12:51 pm, amitabh.me...@g mail.com wrote:
Hi

I havent used MQT before. Read the online tips and tutorials but none
seems to give any hint for my problem.

I have a base table (base_table) as:

st varchar(25) default 'my_null'
dt timestamp default
'1900-01-01-00.00.00.00000'
num integer default -999999

My requirement is that for any of these default value in base table,
null should be populated in the materialized view.
I tried the following to create a mqt:

CREATE TABLE OUT_table AS (SELECT
CASE DT WHEN
'1900-01-01-00.00.00.000000 ' THEN null ELSE DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST FROM
base_table)
DATA INITIALLY DEFERRED REFRESH DEFERRED

Then tried creating the staging table:

create table m_out_table for out_table propagate
immediate

This gave me error: SQL20058N The fullselect specified for the
materialized query table "test.OUT_table " is not valid. Reason code =
"7

Can, the thing that I am trying to do (put null values for 'my_null'
etc), be done? If yes, how?

Thanks.
If you use a staging table you must obey the same rules as for an MQT
refresh immediate:

db2 "? SQL20058N"
SQL20058N The fullselect specified for the materialized query
table "<table-name >" is not valid. Reason code =
"<reason-code>".

Explanation:

The materialized query table definition has specific rules
regarding the contents of the fullselect. Some rules are based on
the materialized query table options (REFRESH DEFERRED or REFRESH
IMMEDIATE) while others are based on whether or not the table is
replicated. The fullselect in the CREATE TABLE statement that
returned this condition violates at least one of the rules as
described in the SQL Reference.

This error may occur during the creation of a staging table. In
such a case, the error applies to the query used in the
definition of the materialized query table with which the staging
table is associated.

The statement cannot be processed because it violates a
restriction as indicated by the following reason code:
[...]
7 When REFRESH IMMEDIATE is specified:

o the materialized query table must not contain duplicate rows

o when a GROUP BY clause is specified, all GROUP BY items must
be included in the select list

o when a GROUP BY clause is specified which contains GROUPING
SETS, CUBE, or ROLLUP, then no grouping sets can be repeated,
and if C is a nullable GROUP BY item that appears within
GROUPING SETS, CUBE, or ROLLUP, then GROUPING(C) must appear
in the select list

o when no GROUP BY clause is present, then the underlying
tables must each have at least one unique key defined, and
all columns of these keys must appear in the select list of
the materialized query table definition
[...]
7 Create the materialized query table as REFRESH DEFERRED, or

o correct the CREATE TABLE statement to ensure all GROUP BY
items are in the select list

o correct the GROUP BY clause to ensure there are no duplicate
grouping sets

o remove the nullable column, C, or add GROUPING(C) in the
select list

o correct the CREATE TABLE statement to ensure at least one
unique key from each table referenced in the query appears in
the select list
Why do you need an MQT in the first place, can't you use a view
instead?

CREATE VIEW OUT_table AS
SELECT CASE DT WHEN '1900-01-01-00.00.00.000000 ' THEN null ELSE
DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST
FROM base_table;

Another option is to add generated columns for the transformations ,
but I would aim for the view
/Lennart

Jan 7 '08 #2
On Jan 7, 7:43 pm, Lennart <Erik.Lennart.J ons...@gmail.co mwrote:
On Jan 7, 12:51 pm, amitabh.me...@g mail.com wrote:
Hi
I havent used MQT before. Read the online tips and tutorials but none
seems to give any hint for my problem.
I have a base table (base_table) as:
st varchar(25) default 'my_null'
dt timestamp default
'1900-01-01-00.00.00.00000'
num integer default -999999
My requirement is that for any of these default value in base table,
null should be populated in the materialized view.
I tried the following to create a mqt:
CREATE TABLE OUT_table AS (SELECT
CASE DT WHEN
'1900-01-01-00.00.00.000000 ' THEN null ELSE DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST FROM
base_table)
DATA INITIALLY DEFERRED REFRESH DEFERRED
Then tried creating the staging table:
create table m_out_table for out_table propagate
immediate
This gave me error: SQL20058N The fullselect specified for the
materialized query table "test.OUT_table " is not valid. Reason code =
"7
Can, the thing that I am trying to do (put null values for 'my_null'
etc), be done? If yes, how?
Thanks.

If you use a staging table you must obey the same rules as for an MQT
refresh immediate:

db2 "? SQL20058N"

SQL20058N The fullselect specified for the materialized query
table "<table-name >" is not valid. Reason code =
"<reason-code>".

Explanation:

The materialized query table definition has specific rules
regarding the contents of the fullselect. Some rules are based on
the materialized query table options (REFRESH DEFERRED or REFRESH
IMMEDIATE) while others are based on whether or not the table is
replicated. The fullselect in the CREATE TABLE statement that
returned this condition violates at least one of the rules as
described in the SQL Reference.

This error may occur during the creation of a staging table. In
such a case, the error applies to the query used in the
definition of the materialized query table with which the staging
table is associated.

The statement cannot be processed because it violates a
restriction as indicated by the following reason code:
[...]
7 When REFRESH IMMEDIATE is specified:

o the materialized query table must not contain duplicate rows

o when a GROUP BY clause is specified, all GROUP BY items must
be included in the select list

o when a GROUP BY clause is specified which contains GROUPING
SETS, CUBE, or ROLLUP, then no grouping sets can be repeated,
and if C is a nullable GROUP BY item that appears within
GROUPING SETS, CUBE, or ROLLUP, then GROUPING(C) must appear
in the select list

o when no GROUP BY clause is present, then the underlying
tables must each have at least one unique key defined, and
all columns of these keys must appear in the select list of
the materialized query table definition
[...]
7 Create the materialized query table as REFRESH DEFERRED, or

o correct the CREATE TABLE statement to ensure all GROUP BY
items are in the select list

o correct the GROUP BY clause to ensure there are no duplicate
grouping sets

o remove the nullable column, C, or add GROUPING(C) in the
select list

o correct the CREATE TABLE statement to ensure at least one
unique key from each table referenced in the query appears in
the select list

Why do you need an MQT in the first place, can't you use a view
instead?

CREATE VIEW OUT_table AS
SELECT CASE DT WHEN '1900-01-01-00.00.00.000000 ' THEN null ELSE
DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST
FROM base_table;

Another option is to add generated columns for the transformations ,
but I would aim for the view

/Lennart
Thanks Lennart for the reply. But the problem with the view is that I
would not be able to refresh them incrementally if my base table gets
updated (as with mqts). or can i?
Jan 8 '08 #3
On Jan 8, 9:44 am, amitabh.me...@g mail.com wrote:
On Jan 7, 7:43 pm, Lennart <Erik.Lennart.J ons...@gmail.co mwrote:
On Jan 7, 12:51 pm, amitabh.me...@g mail.com wrote:
Hi
I havent used MQT before. Read the online tips and tutorials but none
seems to give any hint for my problem.
I have a base table (base_table) as:
st varchar(25) default 'my_null'
dt timestamp default
'1900-01-01-00.00.00.00000'
num integer default -999999
My requirement is that for any of these default value in base table,
null should be populated in the materialized view.
I tried the following to create a mqt:
CREATE TABLE OUT_table AS (SELECT
CASE DT WHEN
'1900-01-01-00.00.00.000000 ' THEN null ELSE DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST FROM
base_table)
DATA INITIALLY DEFERRED REFRESH DEFERRED
Then tried creating the staging table:
create table m_out_table for out_table propagate
immediate
This gave me error: SQL20058N The fullselect specified for the
materialized query table "test.OUT_table " is not valid. Reason code =
"7
Can, the thing that I am trying to do (put null values for 'my_null'
etc), be done? If yes, how?
Thanks.
If you use a staging table you must obey the same rules as for an MQT
refresh immediate:
db2 "? SQL20058N"
SQL20058N The fullselect specified for the materialized query
table "<table-name >" is not valid. Reason code =
"<reason-code>".
Explanation:
The materialized query table definition has specific rules
regarding the contents of the fullselect. Some rules are based on
the materialized query table options (REFRESH DEFERRED or REFRESH
IMMEDIATE) while others are based on whether or not the table is
replicated. The fullselect in the CREATE TABLE statement that
returned this condition violates at least one of the rules as
described in the SQL Reference.
This error may occur during the creation of a staging table. In
such a case, the error applies to the query used in the
definition of the materialized query table with which the staging
table is associated.
The statement cannot be processed because it violates a
restriction as indicated by the following reason code:
[...]
7 When REFRESH IMMEDIATE is specified:
o the materialized query table must not contain duplicate rows
o when a GROUP BY clause is specified, all GROUP BY items must
be included in the select list
o when a GROUP BY clause is specified which contains GROUPING
SETS, CUBE, or ROLLUP, then no grouping sets can be repeated,
and if C is a nullable GROUP BY item that appears within
GROUPING SETS, CUBE, or ROLLUP, then GROUPING(C) must appear
in the select list
o when no GROUP BY clause is present, then the underlying
tables must each have at least one unique key defined, and
all columns of these keys must appear in the select list of
the materialized query table definition
[...]
7 Create the materialized query table as REFRESH DEFERRED, or
o correct the CREATE TABLE statement to ensure all GROUP BY
items are in the select list
o correct the GROUP BY clause to ensure there are no duplicate
grouping sets
o remove the nullable column, C, or add GROUPING(C) in the
select list
o correct the CREATE TABLE statement to ensure at least one
unique key from each table referenced in the query appears in
the select list
Why do you need an MQT in the first place, can't you use a view
instead?
CREATE VIEW OUT_table AS
SELECT CASE DT WHEN '1900-01-01-00.00.00.000000 ' THEN null ELSE
DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST
FROM base_table;
Another option is to add generated columns for the transformations ,
but I would aim for the view
/Lennart

Thanks Lennart for the reply. But the problem with the view is that I
would not be able to refresh them incrementally if my base table gets
updated (as with mqts). or can i?
Also since I am not using REFRESH IMMEDIATE, I cant understand how
this error is coming.
Jan 8 '08 #4
On Jan 8, 5:44 am, amitabh.me...@g mail.com wrote:
On Jan 7, 7:43 pm, Lennart <Erik.Lennart.J ons...@gmail.co mwrote:
On Jan 7, 12:51 pm, amitabh.me...@g mail.com wrote:
Hi
I havent used MQT before. Read the online tips and tutorials but none
seems to give any hint for my problem.
I have a base table (base_table) as:
st varchar(25) default 'my_null'
dt timestamp default
'1900-01-01-00.00.00.00000'
num integer default -999999
My requirement is that for any of these default value in base table,
null should be populated in the materialized view.
I tried the following to create a mqt:
CREATE TABLE OUT_table AS (SELECT
CASE DT WHEN
'1900-01-01-00.00.00.000000 ' THEN null ELSE DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST FROM
base_table)
DATA INITIALLY DEFERRED REFRESH DEFERRED
Then tried creating the staging table:
create table m_out_table for out_table propagate
immediate
This gave me error: SQL20058N The fullselect specified for the
materialized query table "test.OUT_table " is not valid. Reason code =
"7
Can, the thing that I am trying to do (put null values for 'my_null'
etc), be done? If yes, how?
Thanks.
If you use a staging table you must obey the same rules as for an MQT
refresh immediate:
db2 "? SQL20058N"
SQL20058N The fullselect specified for the materialized query
table "<table-name >" is not valid. Reason code =
"<reason-code>".
Explanation:
The materialized query table definition has specific rules
regarding the contents of the fullselect. Some rules are based on
the materialized query table options (REFRESH DEFERRED or REFRESH
IMMEDIATE) while others are based on whether or not the table is
replicated. The fullselect in the CREATE TABLE statement that
returned this condition violates at least one of the rules as
described in the SQL Reference.
This error may occur during the creation of a staging table. In
such a case, the error applies to the query used in the
definition of the materialized query table with which the staging
table is associated.
The statement cannot be processed because it violates a
restriction as indicated by the following reason code:
[...]
7 When REFRESH IMMEDIATE is specified:
o the materialized query table must not contain duplicate rows
o when a GROUP BY clause is specified, all GROUP BY items must
be included in the select list
o when a GROUP BY clause is specified which contains GROUPING
SETS, CUBE, or ROLLUP, then no grouping sets can be repeated,
and if C is a nullable GROUP BY item that appears within
GROUPING SETS, CUBE, or ROLLUP, then GROUPING(C) must appear
in the select list
o when no GROUP BY clause is present, then the underlying
tables must each have at least one unique key defined, and
all columns of these keys must appear in the select list of
the materialized query table definition
[...]
7 Create the materialized query table as REFRESH DEFERRED, or
o correct the CREATE TABLE statement to ensure all GROUP BY
items are in the select list
o correct the GROUP BY clause to ensure there are no duplicate
grouping sets
o remove the nullable column, C, or add GROUPING(C) in the
select list
o correct the CREATE TABLE statement to ensure at least one
unique key from each table referenced in the query appears in
the select list
Why do you need an MQT in the first place, can't you use a view
instead?
CREATE VIEW OUT_table AS
SELECT CASE DT WHEN '1900-01-01-00.00.00.000000 ' THEN null ELSE
DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST
FROM base_table;
Another option is to add generated columns for the transformations ,
but I would aim for the view
/Lennart

Thanks Lennart for the reply. But the problem with the view is that I
would not be able to refresh them incrementally if my base table gets
updated (as with mqts). or can i?
I'm not sure I understand your question, but a view is sort of a query
stored in the database so you will definitely get updated results from
the view as you update the underlaying tables. In an MQT on the other
hand, the result is physically stored on disk.

HTH
/Lennart
Jan 8 '08 #5
On Jan 8, 5:45 am, amitabh.me...@g mail.com wrote:
On Jan 8, 9:44 am, amitabh.me...@g mail.com wrote:
On Jan 7, 7:43 pm, Lennart <Erik.Lennart.J ons...@gmail.co mwrote:
On Jan 7, 12:51 pm, amitabh.me...@g mail.com wrote:
Hi
I havent used MQT before. Read the online tips and tutorials but none
seems to give any hint for my problem.
I have a base table (base_table) as:
st varchar(25) default 'my_null'
dt timestamp default
'1900-01-01-00.00.00.00000'
num integer default -999999
My requirement is that for any of these default value in base table,
null should be populated in the materialized view.
I tried the following to create a mqt:
CREATE TABLE OUT_table AS (SELECT
CASE DT WHEN
'1900-01-01-00.00.00.000000 ' THEN null ELSE DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST FROM
base_table)
DATA INITIALLY DEFERRED REFRESH DEFERRED
Then tried creating the staging table:
create table m_out_table for out_table propagate
immediate
This gave me error: SQL20058N The fullselect specified for the
materialized query table "test.OUT_table " is not valid. Reason code =
"7
Can, the thing that I am trying to do (put null values for 'my_null'
etc), be done? If yes, how?
Thanks.
If you use a staging table you must obey the same rules as for an MQT
refresh immediate:
db2 "? SQL20058N"
SQL20058N The fullselect specified for the materialized query
table "<table-name >" is not valid. Reason code =
"<reason-code>".
Explanation:
The materialized query table definition has specific rules
regarding the contents of the fullselect. Some rules are based on
the materialized query table options (REFRESH DEFERRED or REFRESH
IMMEDIATE) while others are based on whether or not the table is
replicated. The fullselect in the CREATE TABLE statement that
returned this condition violates at least one of the rules as
described in the SQL Reference.
This error may occur during the creation of a staging table. In
such a case, the error applies to the query used in the
definition of the materialized query table with which the staging
table is associated.
The statement cannot be processed because it violates a
restriction as indicated by the following reason code:
[...]
7 When REFRESH IMMEDIATE is specified:
o the materialized query table must not contain duplicate rows
o when a GROUP BY clause is specified, all GROUP BY items must
be included in the select list
o when a GROUP BY clause is specified which contains GROUPING
SETS, CUBE, or ROLLUP, then no grouping sets can be repeated,
and if C is a nullable GROUP BY item that appears within
GROUPING SETS, CUBE, or ROLLUP, then GROUPING(C) must appear
in the select list
o when no GROUP BY clause is present, then the underlying
tables must each have at least one unique key defined, and
all columns of these keys must appear in the select list of
the materialized query table definition
[...]
7 Create the materialized query table as REFRESH DEFERRED, or
o correct the CREATE TABLE statement to ensure all GROUP BY
items are in the select list
o correct the GROUP BY clause to ensure there are no duplicate
grouping sets
o remove the nullable column, C, or add GROUPING(C) in the
select list
o correct the CREATE TABLE statement to ensure at least one
unique key from each table referenced in the query appears in
the select list
Why do you need an MQT in the first place, can't you use a view
instead?
CREATE VIEW OUT_table AS
SELECT CASE DT WHEN '1900-01-01-00.00.00.000000 ' THEN null ELSE
DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST
FROM base_table;
Another option is to add generated columns for the transformations ,
but I would aim for the view
/Lennart
Thanks Lennart for the reply. But the problem with the view is that I
would not be able to refresh them incrementally if my base table gets
updated (as with mqts). or can i?

Also since I am not using REFRESH IMMEDIATE, I cant understand how
this error is coming.
That's because of the staging table. If you add a staging table to a
"refresh deferred" MQT, youi must obey the same rules as for an
"refresh immediate" MQT
/Lennart
Jan 8 '08 #6
On Jan 8, 6:21 am, Lennart <Erik.Lennart.J ons...@gmail.co mwrote:
On Jan 8, 5:44 am, amitabh.me...@g mail.com wrote:
On Jan 7, 7:43 pm, Lennart <Erik.Lennart.J ons...@gmail.co mwrote:
On Jan 7, 12:51 pm, amitabh.me...@g mail.com wrote:
Hi
I havent used MQT before. Read the online tips and tutorials but none
seems to give any hint for my problem.
I have a base table (base_table) as:
st varchar(25) default 'my_null'
dt timestamp default
'1900-01-01-00.00.00.00000'
num integer default -999999
My requirement is that for any of these default value in base table,
null should be populated in the materialized view.
I tried the following to create a mqt:
CREATE TABLE OUT_table AS (SELECT
CASE DT WHEN
'1900-01-01-00.00.00.000000 ' THEN null ELSE DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST FROM
base_table)
DATA INITIALLY DEFERRED REFRESH DEFERRED
Then tried creating the staging table:
create table m_out_table for out_table propagate
immediate
This gave me error: SQL20058N The fullselect specified for the
materialized query table "test.OUT_table " is not valid. Reason code =
"7
Can, the thing that I am trying to do (put null values for 'my_null'
etc), be done? If yes, how?
Thanks.
If you use a staging table you must obey the same rules as for an MQT
refresh immediate:
db2 "? SQL20058N"
SQL20058N The fullselect specified for the materialized query
table "<table-name >" is not valid. Reason code =
"<reason-code>".
Explanation:
The materialized query table definition has specific rules
regarding the contents of the fullselect. Some rules are based on
the materialized query table options (REFRESH DEFERRED or REFRESH
IMMEDIATE) while others are based on whether or not the table is
replicated. The fullselect in the CREATE TABLE statement that
returned this condition violates at least one of the rules as
described in the SQL Reference.
This error may occur during the creation of a staging table. In
such a case, the error applies to the query used in the
definition of the materialized query table with which the staging
table is associated.
The statement cannot be processed because it violates a
restriction as indicated by the following reason code:
[...]
7 When REFRESH IMMEDIATE is specified:
o the materialized query table must not contain duplicate rows
o when a GROUP BY clause is specified, all GROUP BY items must
be included in the select list
o when a GROUP BY clause is specified which contains GROUPING
SETS, CUBE, or ROLLUP, then no grouping sets can be repeated,
and if C is a nullable GROUP BY item that appears within
GROUPING SETS, CUBE, or ROLLUP, then GROUPING(C) must appear
in the select list
o when no GROUP BY clause is present, then the underlying
tables must each have at least one unique key defined, and
all columns of these keys must appear in the select list of
the materialized query table definition
[...]
7 Create the materialized query table as REFRESH DEFERRED, or
o correct the CREATE TABLE statement to ensure all GROUP BY
items are in the select list
o correct the GROUP BY clause to ensure there are no duplicate
grouping sets
o remove the nullable column, C, or add GROUPING(C) in the
select list
o correct the CREATE TABLE statement to ensure at least one
unique key from each table referenced in the query appears in
the select list
Why do you need an MQT in the first place, can't you use a view
instead?
CREATE VIEW OUT_table AS
SELECT CASE DT WHEN '1900-01-01-00.00.00.000000 ' THEN null ELSE
DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST
FROM base_table;
Another option is to add generated columns for the transformations ,
but I would aim for the view
/Lennart
Thanks Lennart for the reply. But the problem with the view is that I
would not be able to refresh them incrementally if my base table gets
updated (as with mqts). or can i?

I'm not sure I understand your question, but a view is sort of a query
stored in the database so you will definitely get updated results from
the view as you update the underlaying tables. In an MQT on the other
hand, the result is physically stored on disk.
That is, with a view you don't need to do any refresh. It is refreshed
by definition

/Lennart
Jan 8 '08 #7
On Jan 8, 10:26 am, Lennart <Erik.Lennart.J ons...@gmail.co mwrote:
On Jan 8, 6:21 am, Lennart <Erik.Lennart.J ons...@gmail.co mwrote:
On Jan 8, 5:44 am, amitabh.me...@g mail.com wrote:
On Jan 7, 7:43 pm, Lennart <Erik.Lennart.J ons...@gmail.co mwrote:
On Jan 7, 12:51 pm, amitabh.me...@g mail.com wrote:
Hi
I havent used MQT before. Read the online tips and tutorials but none
seems to give any hint for my problem.
I have a base table (base_table) as:
st varchar(25) default 'my_null'
dt timestamp default
'1900-01-01-00.00.00.00000'
num integer default -999999
My requirement is that for any of these default value in base table,
null should be populated in the materialized view.
I tried the following to create a mqt:
CREATE TABLE OUT_table AS (SELECT
CASE DT WHEN
'1900-01-01-00.00.00.000000 ' THEN null ELSE DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST FROM
base_table)
DATA INITIALLY DEFERRED REFRESH DEFERRED
Then tried creating the staging table:
create table m_out_table for out_table propagate
immediate
This gave me error: SQL20058N The fullselect specified for the
materialized query table "test.OUT_table " is not valid. Reason code =
"7
Can, the thing that I am trying to do (put null values for 'my_null'
etc), be done? If yes, how?
Thanks.
If you use a staging table you must obey the same rules as for an MQT
refresh immediate:
db2 "? SQL20058N"
SQL20058N The fullselect specified for the materialized query
table "<table-name >" is not valid. Reason code =
"<reason-code>".
Explanation:
The materialized query table definition has specific rules
regarding the contents of the fullselect. Some rules are based on
the materialized query table options (REFRESH DEFERRED or REFRESH
IMMEDIATE) while others are based on whether or not the table is
replicated. The fullselect in the CREATE TABLE statement that
returned this condition violates at least one of the rules as
described in the SQL Reference.
This error may occur during the creation of a staging table. In
such a case, the error applies to the query used in the
definition of the materialized query table with which the staging
table is associated.
The statement cannot be processed because it violates a
restriction as indicated by the following reason code:
[...]
7 When REFRESH IMMEDIATE is specified:
o the materialized query table must not contain duplicate rows
o when a GROUP BY clause is specified, all GROUP BY items must
be included in the select list
o when a GROUP BY clause is specified which contains GROUPING
SETS, CUBE, or ROLLUP, then no grouping sets can be repeated,
and if C is a nullable GROUP BY item that appears within
GROUPING SETS, CUBE, or ROLLUP, then GROUPING(C) must appear
in the select list
o when no GROUP BY clause is present, then the underlying
tables must each have at least one unique key defined, and
all columns of these keys must appear in the select list of
the materialized query table definition
[...]
7 Create the materialized query table as REFRESH DEFERRED, or
o correct the CREATE TABLE statement to ensure all GROUP BY
items are in the select list
o correct the GROUP BY clause to ensure there are no duplicate
grouping sets
o remove the nullable column, C, or add GROUPING(C) in the
select list
o correct the CREATE TABLE statement to ensure at least one
unique key from each table referenced in the query appears in
the select list
Why do you need an MQT in the first place, can't you use a view
instead?
CREATE VIEW OUT_table AS
SELECT CASE DT WHEN '1900-01-01-00.00.00.000000 ' THEN null ELSE
DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST
FROM base_table;
Another option is to add generated columns for the transformations ,
but I would aim for the view
/Lennart
Thanks Lennart for the reply. But the problem with the view is that I
would not be able to refresh them incrementally if my base table gets
updated (as with mqts). or can i?
I'm not sure I understand your question, but a view is sort of a query
stored in the database so you will definitely get updated results from
the view as you update the underlaying tables. In an MQT on the other
hand, the result is physically stored on disk.

That is, with a view you don't need to do any refresh. It is refreshed
by definition

/Lennart
The problem with the view is that it will get updated as soon my base
table is updated. I dont want that. I want to refresh my"snapshot" as
n when required. So i found out that mqt was solving my purpose. I cud
update them as n when required.
Any other idea?
Jan 8 '08 #8
On Jan 8, 6:50 am, amitabh.me...@g mail.com wrote:
On Jan 8, 10:26 am, Lennart <Erik.Lennart.J ons...@gmail.co mwrote:
On Jan 8, 6:21 am, Lennart <Erik.Lennart.J ons...@gmail.co mwrote:
On Jan 8, 5:44 am, amitabh.me...@g mail.com wrote:
On Jan 7, 7:43 pm, Lennart <Erik.Lennart.J ons...@gmail.co mwrote:
On Jan 7, 12:51 pm, amitabh.me...@g mail.com wrote:
Hi
I havent used MQT before. Read the online tips and tutorials but none
seems to give any hint for my problem.
I have a base table (base_table) as:
st varchar(25) default 'my_null'
dt timestamp default
'1900-01-01-00.00.00.00000'
num integer default -999999
My requirement is that for any of these default value in base table,
null should be populated in the materialized view.
I tried the following to create a mqt:
CREATE TABLE OUT_table AS (SELECT
CASE DT WHEN
'1900-01-01-00.00.00.000000 ' THEN null ELSE DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST FROM
base_table)
DATA INITIALLY DEFERRED REFRESH DEFERRED
Then tried creating the staging table:
create table m_out_table for out_table propagate
immediate
This gave me error: SQL20058N The fullselect specified for the
materialized query table "test.OUT_table " is not valid. Reason code =
"7
Can, the thing that I am trying to do (put null values for 'my_null'
etc), be done? If yes, how?
Thanks.
If you use a staging table you must obey the same rules as for an MQT
refresh immediate:
db2 "? SQL20058N"
SQL20058N The fullselect specified for the materialized query
table "<table-name >" is not valid. Reason code =
"<reason-code>".
Explanation:
The materialized query table definition has specific rules
regarding the contents of the fullselect. Some rules are based on
the materialized query table options (REFRESH DEFERRED or REFRESH
IMMEDIATE) while others are based on whether or not the table is
replicated. The fullselect in the CREATE TABLE statement that
returned this condition violates at least one of the rules as
described in the SQL Reference.
This error may occur during the creation of a staging table. In
such a case, the error applies to the query used in the
definition of the materialized query table with which the staging
table is associated.
The statement cannot be processed because it violates a
restriction as indicated by the following reason code:
[...]
7 When REFRESH IMMEDIATE is specified:
o the materialized query table must not contain duplicate rows
o when a GROUP BY clause is specified, all GROUP BY items must
be included in the select list
o when a GROUP BY clause is specified which contains GROUPING
SETS, CUBE, or ROLLUP, then no grouping sets can be repeated,
and if C is a nullable GROUP BY item that appears within
GROUPING SETS, CUBE, or ROLLUP, then GROUPING(C) must appear
in the select list
o when no GROUP BY clause is present, then the underlying
tables must each have at least one unique key defined, and
all columns of these keys must appear in the select list of
the materialized query table definition
[...]
7 Create the materialized query table as REFRESH DEFERRED, or
o correct the CREATE TABLE statement to ensure all GROUP BY
items are in the select list
o correct the GROUP BY clause to ensure there are no duplicate
grouping sets
o remove the nullable column, C, or add GROUPING(C) in the
select list
o correct the CREATE TABLE statement to ensure at least one
unique key from each table referenced in the query appears in
the select list
Why do you need an MQT in the first place, can't you use a view
instead?
CREATE VIEW OUT_table AS
SELECT CASE DT WHEN '1900-01-01-00.00.00.000000 ' THEN null ELSE
DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST
FROM base_table;
Another option is to add generated columns for the transformations ,
but I would aim for the view
/Lennart
Thanks Lennart for the reply. But the problem with the view is that I
would not be able to refresh them incrementally if my base table gets
updated (as with mqts). or can i?
I'm not sure I understand your question, but a view is sort of a query
stored in the database so you will definitely get updated results from
the view as you update the underlaying tables. In an MQT on the other
hand, the result is physically stored on disk.
That is, with a view you don't need to do any refresh. It is refreshed
by definition
/Lennart

The problem with the view is that it will get updated as soon my base
table is updated. I dont want that. I want to refresh my"snapshot" as
n when required. So i found out that mqt was solving my purpose. I cud
update them as n when required.
Any other idea?
Why do you need the staging table?
/Lennart
Jan 8 '08 #9
On Jan 8, 12:03 pm, Lennart <Erik.Lennart.J ons...@gmail.co mwrote:
On Jan 8, 6:50 am, amitabh.me...@g mail.com wrote:
On Jan 8, 10:26 am, Lennart <Erik.Lennart.J ons...@gmail.co mwrote:
On Jan 8, 6:21 am, Lennart <Erik.Lennart.J ons...@gmail.co mwrote:
On Jan 8, 5:44 am, amitabh.me...@g mail.com wrote:
On Jan 7, 7:43 pm, Lennart <Erik.Lennart.J ons...@gmail.co mwrote:
On Jan 7, 12:51 pm, amitabh.me...@g mail.com wrote:
Hi
I havent used MQT before. Read the online tips and tutorials but none
seems to give any hint for my problem.
I have a base table (base_table) as:
st varchar(25) default 'my_null'
dt timestamp default
'1900-01-01-00.00.00.00000'
num integer default -999999
My requirement is that for any of these default value in base table,
null should be populated in the materialized view.
I tried the following to create a mqt:
CREATE TABLE OUT_table AS (SELECT
CASE DT WHEN
'1900-01-01-00.00.00.000000 ' THEN null ELSE DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST FROM
base_table)
DATA INITIALLY DEFERRED REFRESH DEFERRED
Then tried creating the staging table:
create table m_out_table for out_table propagate
immediate
This gave me error: SQL20058N The fullselect specified for the
materialized query table "test.OUT_table " is not valid. Reason code =
"7
Can, the thing that I am trying to do (put null values for 'my_null'
etc), be done? If yes, how?
Thanks.
If you use a staging table you must obey the same rules as for an MQT
refresh immediate:
db2 "? SQL20058N"
SQL20058N The fullselect specified for the materialized query
table "<table-name >" is not valid. Reason code =
"<reason-code>".
Explanation:
The materialized query table definition has specific rules
regarding the contents of the fullselect. Some rules are based on
the materialized query table options (REFRESH DEFERRED or REFRESH
IMMEDIATE) while others are based on whether or not the table is
replicated. The fullselect in the CREATE TABLE statement that
returned this condition violates at least one of the rules as
described in the SQL Reference.
This error may occur during the creation of a staging table. In
such a case, the error applies to the query used in the
definition of the materialized query table with which the staging
table is associated.
The statement cannot be processed because it violates a
restriction as indicated by the following reason code:
[...]
7 When REFRESH IMMEDIATE is specified:
o the materialized query table must not contain duplicate rows
o when a GROUP BY clause is specified, all GROUP BY items must
be included in the select list
o when a GROUP BY clause is specified which contains GROUPING
SETS, CUBE, or ROLLUP, then no grouping sets can be repeated,
and if C is a nullable GROUP BY item that appears within
GROUPING SETS, CUBE, or ROLLUP, then GROUPING(C) must appear
in the select list
o when no GROUP BY clause is present, then the underlying
tables must each have at least one unique key defined, and
all columns of these keys must appear in the select list of
the materialized query table definition
[...]
7 Create the materialized query table as REFRESH DEFERRED, or
o correct the CREATE TABLE statement to ensure all GROUP BY
items are in the select list
o correct the GROUP BY clause to ensure there are no duplicate
grouping sets
o remove the nullable column, C, or add GROUPING(C) in the
select list
o correct the CREATE TABLE statement to ensure at least one
unique key from each table referenced in the query appears in
the select list
Why do you need an MQT in the first place, can't you use a view
instead?
CREATE VIEW OUT_table AS
SELECT CASE DT WHEN '1900-01-01-00.00.00.000000 ' THEN null ELSE
DT END DT,
CASE NUM WHEN -999999 THEN null ELSE NUM END NUM,
CASE ST WHEN 'my_null' THEN null ELSE ST END ST
FROM base_table;
Another option is to add generated columns for the transformations ,
but I would aim for the view
/Lennart
Thanks Lennart for the reply. But the problem with the view is that I
would not be able to refresh them incrementally if my base table gets
updated (as with mqts). or can i?
I'm not sure I understand your question, but a view is sort of a query
stored in the database so you will definitely get updated results from
the view as you update the underlaying tables. In an MQT on the other
hand, the result is physically stored on disk.
That is, with a view you don't need to do any refresh. It is refreshed
by definition
/Lennart
The problem with the view is that it will get updated as soon my base
table is updated. I dont want that. I want to refresh my"snapshot" as
n when required. So i found out that mqt was solving my purpose. I cud
update them as n when required.
Any other idea?

Why do you need the staging table?

/Lennart
So that I can incrementally refresh a REFRESH DEFERRED MQT. The idea
is to use the staging table to incrementally refresh the MQT, rather
than regenerate the MQT from scratch and so enhance the performance.
Jan 8 '08 #10

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

11
3762
by: Kostatus | last post by:
I have a virtual function in a base class, which is then overwritten by a function of the same name in a publically derived class. When I call the function using a pointer to the derived class (ClassB* b; b->func(); ) the base-class function is called instead of the new function in the derived class. All other similar functions (virtual in the base class and overwritten in the the derived class) work fine, it's just this one function. ...
117
7270
by: Peter Olcott | last post by:
www.halting-problem.com
18
6177
by: Ian Stanley | last post by:
Hi, Continuing my strcat segmentation fault posting- I have a problem which occurs when appending two sting literals using strcat. I have tried to fix it by writing my own function that does the strcat (mystract). Program below. However this appears not to have fixed the problem and I don't know why it shouldn't ? Any further help as to what else I am doing wrong will be appreciated regards
28
5223
by: Jon Davis | last post by:
If I have a class with a virtual method, and a child class that overrides the virtual method, and then I create an instance of the child class AS A base class... BaseClass bc = new ChildClass(); .... and then call the virtual method, why is it that the base class's method is called instead of the overridden method? How do I fix this if I don't know at runtime what the child class is? I'm using Activator.CreateInstance() to load the...
6
3813
by: Ammar | last post by:
Dear All, I'm facing a small problem. I have a portal web site, that contains articles, for each article, the end user can send a comment about the article. The problem is: I the comment length is more that 1249 bytes, then the progress bar of the browser will move too slow and then displaying that the page not found!!!! If the message is less than or equal to 1249 then no problem.
16
4929
by: Dany | last post by:
Our web service was working fine until we installed .net Framework 1.1 service pack 1. Uninstalling SP1 is not an option because our largest customer says service packs marked as "critical" by Microsoft must be installed on their servers. Now german Umlaute (ä, ü, ö) and quotes are returned incorrectly in SOAP fault responses. This can be easily verified: Implement the following in a web service method (just raises a SOAPException with a...
2
4556
by: Mike Collins | last post by:
I cannot get the correct drop down list value from a drop down I have on my web form. I get the initial value that was loaded in the list. It was asked by someone else what the autopostback was set to...it is set to false. Can someone show me what I am doing wrong and tell me the correct way? Thank you. In the page load event, I am doing the following:
0
2970
by: =?Utf-8?B?am8uZWw=?= | last post by:
Hello All, I am developing an Input Methop (IM) for PocketPC / Windows Mobile (PPC/WM). On some devices the IM will not start. The IM appears in the IM-List but when it is selected from the list athe result is that the standard (QWERTY) keyboard appears. I found that many ( all?) ISV's who make IM's have customers reporting this problem. My research on the internet brought me to the conclusion it is some
1
5123
by: sherifbk | last post by:
Problem description ============== - I have 4 clients and 1 server (SQL server) - 3 clients are Monitoring console 1 client is operation console - Monitoring console collects some data from the control unit and store them into the Sql server - The operation console then retrieve this data from the sql for reporting and statistics purposes - I am using ODBC connection - The problem is that the operation console is not able to...
9
3662
by: AceKnocks | last post by:
I am working on a framework design problem in which I have to design a C++ based framework capable of solving three puzzles for now but actually it should work with a general puzzle of any kind and I need your able help in this activity. Objective - In this activity you will design a framework capable of solving any puzzle of a specific type and, as a test of this framework, use the framework to solve a very simple puzzle. In this first...
0
9645
marktang
by: marktang | last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However, people are often confused as to whether an ONU can Work As a Router. In this blog post, we’ll explore What is ONU, What Is Router, ONU & Router’s main usage, and What is the difference between ONU and Router. Let’s take a closer look ! Part I. Meaning of...
0
10341
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers, it seems that the internal comparison operator "<=>" tries to promote arguments from unsigned to signed. This is as boiled down as I can make it. Here is my compilation command: g++-12 -std=c++20 -Wnarrowing bit_field.cpp Here is the code in...
1
10095
by: Hystou | last post by:
Overview: Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows Update option using the Control Panel or Settings app; it automatically checks for updates and installs any it finds, whether you like it or not. For most users, this new feature is actually very convenient. If you want to control the update process,...
0
9954
tracyyun
by: tracyyun | last post by:
Dear forum friends, With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each protocol has its own unique characteristics and advantages, but as a user who is planning to build a smart home system, I am a bit confused by the choice of these technologies. I'm particularly interested in Zigbee because I've heard it does some...
0
8979
agi2029
by: agi2029 | last post by:
Let's talk about the concept of autonomous AI software engineers and no-code agents. These AIs are designed to manage the entire lifecycle of a software development project—planning, coding, testing, and deployment—without human intervention. Imagine an AI that can take a project description, break it down, write the code, debug it, and then launch it, all on its own.... Now, this would greatly impact the work of software developers. The idea...
0
6741
by: conductexam | last post by:
I have .net C# application in which I am extracting data from word file and save it in database particularly. To store word all data as it is I am converting the whole word file firstly in HTML and then checking html paragraph one by one. At the time of converting from word file to html my equations which are in the word document file was convert into image. Globals.ThisAddIn.Application.ActiveDocument.Select();...
0
5383
by: TSSRALBI | last post by:
Hello I'm a network technician in training and I need your help. I am currently learning how to create and manage the different types of VPNs and I have a question about LAN-to-LAN VPNs. The last exercise I practiced was to create a LAN-to-LAN VPN between two Pfsense firewalls, by using IPSEC protocols. I succeeded, with both firewalls in the same network. But I'm wondering if it's possible to do the same thing, with 2 Pfsense firewalls...
0
5513
by: adsilva | last post by:
A Windows Forms form does not have the event Unload, like VB6. What one acts like?
1
4054
by: 6302768590 | last post by:
Hai team i want code for transfer the data from one system to another through IP address by using C# our system has to for every 5mins then we have to update the data what the data is updated we have to send another system

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.