Importação de Metadados

A seguir, há um exemplo de linha de comando para executar utilitário de Carregamento de Outline, usando o arquivo myprop_relational.properties (detalhado abaixo) como entrada:

OutlineLoad /CP:c:/myprop_relational.properties

O arquivo importará os membros da Conta do aplicativo PS2ORAU mostrado nos parâmetros de conexão JDBC para um aplicativo denominado Test_300. O arquivo de propriedades pode conter várias consultas relacionais. O parâmetro /RIQ determina qual consulta será executada pelo utilitário de Carregamento de Outline.

Para obter uma descrição de /RIQ, consulte Parâmetros da Linha de Comando para o Utilitário de Carregamento de Outline.

Exemplo 5-1 Exemplo: O Arquivo myprop_relational.properties

/A:Test_300
/U:admin
/RIQ: ACCOUNT_QUERY

/D:Account
#
ACCOUNT_QUERY=SELECT O.OBJECT_NAME as Account, (select object_name from hsp_object where object_id = O.PARENT_ID) as Parent from HSP_ACCOUNT A, HSP_MEMBER M, HSP_OBJECT O LEFT OUTER JOIN HSP_STRINGS S ON O.DESCRIPTION = S.STRING_SEQ  WHERE O.OBJECT_ID=M.MEMBER_ID AND M.MEMBER_ID = A.ACCOUNT_ID AND M.MEMBER_ID <> M.DIM_ID ORDER BY O.POSITION
#
ENTITY_QUERY=SELECT O.OBJECT_NAME as Entity, (select object_name from hsp_object where object_id = O.PARENT_ID) as Parent from HSP_ENTITY E, HSP_MEMBER M, HSP_OBJECT O LEFT OUTER JOIN HSP_STRINGS S ON O.DESCRIPTION = S.STRING_SEQ  WHERE O.OBJECT_ID=M.MEMBER_ID AND M.MEMBER_ID = E.ENTITY_ID AND M.MEMBER_ID <> M.DIM_ID ORDER BY O.POSITION

## jdbc connection
/RIC:PS2ORAU
/RIR:jdbc:oracle:thin:@[scl34390]:1521:orcl
/RID:oracle.jdbc.OracleDriver
/RIU:PS2ORAU
/RIP:password

#end myprop_relational.properties file

No exemplo a seguir, uma dimensão de atributo na origem e nos aplicativos de destino tem um nome com mais de 30 caracteres, Size012345678901234567890123456789, que ultrapassa o limite de cabeçalho da coluna Oracle. A consulta no exemplo a seguir é usada para criar um resultado definido a partir da origem a ser importada para o aplicativo de destino. O nome longo da dimensão deve ser apelidado como coluna O.OBJECT_NAME para permitir o uso dessa coluna como nome da dimensão de atributo.

Exemplo 5-2 Exemplo: Arquivo de Propriedades para Importação de uma Origem de Dados Relacional para um Aplicativo do Planning

/A:TARGET
/U:admin
/IR

/DA:Size012345678901234567890123456789:Entity

/C2A:(OBJECT_NAME,Size012345678901234567890123456789)

ATTRIB_DIM_VAL_QUERY_ORACLE1=SELECT O.OBJECT_NAME, (select object_name from PS3ORA.hsp_object where object_id = O.PARENT_ID) as Parent from PS3ORA.HSP_OBJECT O WHERE O.OBJECT_ID IN (select AM.ATTR_MEM_ID from PS3ORA.hsp_attribute_member AM, PS3ORA.HSP_OBJECT O where AM.ATTR_ID =(select OBJECT_ID from PS3ORA.hsp_object where OBJECT_NAME='Size012345678901234567890123456789')) ORDER BY O.POSITION

Exemplo 5-3 Exemplo: Arquivo de Propriedades para Importação com Alias de uma Origem de Dados Relacional para um Aplicativo do Planning

/A:expe
/U:admin
/IRA
/D:Entity
/C2A:(Member as Entity,anotherReallyLongAliasForAColumnNameItsForEntityThisTimeDifferentFromExport), (Parent, anotherAliasForParent)

/RIQ:select anotherReallyLongAliasForAColumnNameItsForEntityThisTimeDifferentFromExport, Parent from test

Suponha o seguinte com relação ao exemplo anterior:

  • A tabela de 'Teste' tem duas colunas, Membro e Pai, possuindo uma única entrada:


    Esse gráfico mostra a saída da tabela de 'Teste
  • A dimensão Entidade tem um membro, e1, na raiz (Entidade).

Depois de executar a consulta anterior, o membro Ex é adicionado ou atualizado na dimensão Entidade.

Na importação, os aliases das colunas são tratados como uma substituição de string reta, e por isso a cláusula "como" pode funcionar neste caso. Se a coluna Membro foi com nomeada como Entidade, você deverá eliminar o 'Membro como'.

Exemplo 5-4 Exemplo: Utilizando o Parâmetro /C2A para Importar Aliases para Tabela de Alias

/A:TARGET
/U:admin
/IR
/D:Entity

/RIQ:ENT_ALIAS_ASSIGNMENT_QUERY

/C2A:(AliasTableName, Alias: LongAliasTableName012345678901234567890123)

ENT_ALIAS_ASSIGNMENT_QUERY=SELECT O.OBJECT_NAME as Entity, (select object_name from hsp_object where OBJECT_ID=O.PARENT_ID) as Parent, (select OBJECT_NAME from HSP_OBJECT where OBJECT_ID = AL.ALIAS_ID) as AliasTableName  from hsp_object O, HSP_ALIAS AL where (AL.ALIASTBL_ID = (select OBJECT_ID from HSP_OBJECT where OBJECT_NAME =' LongAliasTableName012345678901234567890123') AND O.OBJECT_ID=AL.MEMBER_ID)

Nota:

No exemplo anterior, o aplicativo de destino do Oracle Hyperion Planning e a origem contêm um nome longo de tabela de alias.

Exemplo 5-5 Exemplo: Utilizando o Parâmetro /C2A para Mapear os Nomes de Colunas para Nomes de Propriedade

/RIQ:select c1,c2,c3,c4,c5,c6,c7,c8,c9,c10,c11,c12,c13,c14,c15,c16,c17,c18,c19,c20,c21,c22,c23,c24,c25,c26,c27 from table28

/c2a:(c1, Account), \
(c2, Parent), \
(c3, Alias: Default), \
(c4, Valid For Consolidations), \
(c5, Data Storage), \
(c6, Two Pass Calculation), \
(c7, Description), \
(c8, Formula), \
(c9, UDA), \
(c10, Smart List), \
(c11, Data Type), \
(c12, Hierarchy Type), \
(c13, Enable for Dynamic Children), \
(c14, Number of Possible Dynamic Children), \
(c15, Access Granted to Member Creator), \
(c16, Account Type), \
(c17, Time Balance), \
(c18, Skip Value), \
(c19, Exchange Rate Type), \
(c20, Variance Reporting), \
(c21, Source Plan Type), \
(c22, Plan Type (Plan1)), \
(c23, Aggregation (Plan1)), \
(c24, Plan Type (Plan2)), \
(c25, Aggregation (Plan2)), \
(c26, Plan Type (Plan3)), \
(c27, Aggregation (Plan3))