Friday, 31 July 2009

Data Manager Logmsg() not working, broken, failed


You need to explicitly switch on user messages to get it to work or use the -M in additional options.
Other areas are in the Job Stream or Build properties although these are always overridden with an execute in DM.
Does anyone know how to set User on as a default?

Cognos Datamanager aka ...

Cognos Decisionstream
Cognos Datamanager
Cognos Data manager
Cognos Decision Stream
Cognos DM
IBM Cognos Datamanager

Data Mangler
Data Mgr aka Data Mugger

etc etc cont p.94

Test part of a calculation


See below. If you highlight an expression you will test just that part of the code.
NB This can be confusing if you do it accidentally.

Cognos Datamanager Comments for Variable and Derivation Calculations


Use C++ // syntax as shown opposite
You can also add them past the semi colon which I have not shown here.

Thursday, 30 July 2009

Data Delivery hangs for UPDATE refresh type

The key columns will differ in length or format to the original insertions. Take great care to make them match - see earlier post for some rules and pitfalls.

Import Package Avoid Prompts for Dependents

Individual selections are checked for inclusion of items on which the selection depends. Select All is not.

Therefore select all and deselect the things you don't want.

I know it sounds obvious but I have battled through a mass of pop-ups for want of better to do.

Wednesday, 29 July 2009

Length of Column output to Build Table

1. Length of column = length of column in query.
2. If column is checked against a lookup then if the lookup has a bigger length the output column inherits that. NB This may include static elements in the lookup.
3. You may need to remove and re-instate a lookup to get the output column to accept a changed length. This is probably a bug in DM

THE ONLY WAY TO CONTROL FORMAT AND LENGTH OUTPUT TO YOUR BUILD TABLES IS TO USE DERIVATIONS.

Tuesday, 28 July 2009

Creating a Primary Composite Key for DM Output Table





Tick all the keys you want in your primary key. Do not tick the index button against each column since this creates single indicies and will SLOW up the load.

Instead tick the Index box next to the Index Options.

If you open the index properties (right) then ensure you untick the suppress error when you are developing otherwise the index creation will fail without warning.

The index is not actually a primary key but a unique index since a primary key requires all non nullable columns.



Monday, 27 July 2009

Variables in Datamanager - Manual Unclear

NB Variables are case insensitive

PARISHILTON
parishilton
ParisHilton

are all equivalent.

1. Explicit Declaration of variables can be done at 6 levels.
========== Highest Level ================
(a) As an environment variable
(b) In the command line to invoke DM build or Job Stream
(c) In the Jobstream variables tab
(d) In the Build variables tab
(e) In the DataSource variables tab
(f) In the declaration of a function
========== Lowest Level ================
The lifetime of the variable is the lifetime of the item within which it is defined.

The variable is visible and modifiable to all lower levels unless it is masked when a variable of the same name is declared at a lower level.
NB do NOT use a $ when you declare a variable. It does not complain if you do!

2. In addition to the above levels Variables can be used

(i) In derivations in the Datasource
(ii) In derivations in the Datastream
(iii) In derivations in the Transformation Model

NB Make sure you use a $ to distinguish a variable from a derivation or an argument.

Variables can be assigned to derivations.

$x = y ;

In the event that multiple assignments take place the value returned to the jobstream will be the LAST calculated value.
Derivations can be assigned to variables

eg

$x

or

return $x

3. Implicit declaration is done

When a function is run at the function level during testing then any variables in the function are implicitly defined.
When the Build is run at the build level then any variables at the build are implicitly defined.

If you rely on an implicit definition and run at a higher level then you get this message.
DM-PRS-1001 Error parsing build specification, failed to replace special items;variable 'DI' could not be found
Implicit declaration will not work where you assign a variable to an expression that contains the same variable eg $x := $ x + 1 ;

4. Variable tracing

Does not record every assignment, but seems to be triggered on the creation of a variable. Certainly it shows variables as being incorrectly assigned to a ''.

DM-BLD-0022 The domain size of 256 was exceeded on Dimension 'EmployeeNumber'


This will be when you are aggregating or rejecting duplicates or other action that requires a hash table.
Double click on EmployeeNumber dimension and increase the Domain Size from the default 256.

Saturday, 25 July 2009

IBM Datamanager training at Staines

If you stay at the Travelodge next to TK maxx make sure you get a room on the second floor as the floor board creak otherwise.

The instructor, Salim, was excellent. The course emphasises Kimball and his methods of Warehousing. Not enough emphasis is placed on Variables and Functions which turn out to be an integral part of DM and only get one chapter.

Overall very good and the bacon butty with tabasco from the IBM canteen is a great way to start the day.

DM-EXP-0003 An expression validation error occurred

DM-EXP-0003 An expression validation error occurred at position 220

Unknown variable '$aperiod'.

Recheck the variable and in the function or calculation and you will find trailing blanks to remove.

Using Cognos Data Manager to produce TM1 cubes

The key is to have the TM1 binaries in your Windows PATH variable.

Further info here

http://forums.olapforums.com/viewtopic.php?f=3&t=1269

How to Parameterize SQL from your Data Source


1. Set up a variable for a Fact Build by right clicking properties (see picture)
2. The key to embedding the parameter is to use the curly brackets in your SQL.
select "SecondedToFromRate",
"SecondedToFromLegacySystemID",
"SecondedToFromLegacyEmployeeID", "GCI"
FROM "PeoplePortal_Headcount"
WHERE D_I = '{$DI}'