Como encavalitar tabelas

images/thumbnail.jpg - Thumbnail

Às vezes temos de criar uma tabela Z. Às vezes temos até de criar várias tabelas Z. Às vezes estas tabelas estão relacionadas de alguma forma. Como quando uma contém dados de cabeçalho e a outra dados de item, por exemplo. Ora se estão relacionadas pode dar jeito que sejam editadas em conjunto. É para isso que servem os Clusters de Visão (view cluster).

Este artigo ensina tintim por tintim a fazer um Cluster de Visão que relaciona duas tabelas.

1. Criar tabela de cabeçalho ZTIPO (SE11)

Na SE11, cria a tabela de cabeçalhos ZTIPO com os seguintes campos:

  • MANDT

  • TIPOID

  • DESCRICAO

image

Faz tudo como sempre fazes com uma excepção: no separador “entrega e actualização” garante que a opção “atualiz.visão tabs.” tem o valor “exibição/actualização permitida com restrição”. Isto serve para impedir que a tabela possa ser mantida independentemente (na SM30).

Agora cria os ecrãs de manutenção desta tabela.

image

2. Criar tabela de ZANEDOTA (SE11)

Na SE11, cria a tabela de itens ZANEDOTA com os seguintes campos:

  • MANDT (chave)

  • TIPOID (chave)

  • ANEDOTAID

  • DESCRICAO

image

Desta vez, na opção “atualiz. visão tabs.” escolhe a opção “exibição/actualização não permitida”. Isto porque esta tabela não vai ser usada na manutenção mas sim uma vista criada sobre ela. Por isso, não cries os ecrãs de manutenção desta tabela.

Cria a chave externa para o campo TIPOID fazendo referência à tabela ZTIPO.

image

3. Criar vista de actualização ZANEDOTA_V (SE11)

Na SE11, cria a vista de actualização ZANEDOTA_V, associa-lhe a tabela ZANEDOTA e escolhe o separador “Campos visão”. Nota que ele mostra automaticamente os campos da chave. Adiciona-lhe agora tu o campo DESCRICAO.

image

Nota a 4ª coluna chamada “Caracterização actualização para campo visão”. Esta coluna é muito importante. Na linha do campo TIPOID preenche essa coluna com o valor S (campo visão utilizado para formatação subset). Isto na prática quer dizer que, sendo a tabela ZANEDOTA dependente da tabela ZTIPO, o campo ZANEDOTA-TIPOID será herdado da ZTIPO-TIPOID e será preenchido automaticamente. Se não entendeste não te preocupes, falarei disso mais tarde.

No separador “Status at.”, vai ao campo “Data Browser/atualiz.visão tabs.” e escolhe o valor “Exibição/atualização permitida com restrição” para evitar que se possa manter independentemente esta vista (na SM30).

Finalmente, cria os ecrãs de manutenção desta vista.

image

E pronto, já está. Grava e vai-te embora da SE11.

4. Criar cluster de visão (SE54)

Na transacção SE54 escolhe a opção “ProcessCluster visão” (que raio de traduções mas enfim). Vais parar a um novo ecrã onde deverás inserir o nome do nosso cluster de visão: ZANEDOTAS. Depois escolhe “criar/modificar”. E pronto, será aqui que tudo vai acontecer.

image

No menu da esquerda escolhe “Estrutura de objecto”. Aí vais definir as duas tabelas e como se relacionam.

Na primeira linha introduz a ZTIPO conforme está aqui:

image

Depois selecciona-a, escolhe a opção “dependência de campos” e garante que está conforme aqui se vê:

image

De volta à “estrutura de objecto”, introduz na segunda linha a vista de actualização ZANEDOTA_V conforme aqui se vê:

image

Depois selecciona-a, escolhe a opção “dependência de campos” e garante que está como aqui se vê:

image

Pronto, já estão as duas configuradas. Agora é só gravar e activar. Escolhe a opção “entrada de cabeçalho” e depois lá à direita espreme o botão “Ativar”. Ele vai perguntar-te se pode alterar os ecrãs de manutenção e tu obedientemente vais dizer que sim.

image

5. Experimentar cluster de visão (SM34)

Se tudo tiver sido feito como deve de ser, agora basta ir à transacção SM34, introduzir o cluster de visão ZANEDOTAS e editar as duas tabelas em conjunto pois lá elas estão encavalitadas uma na outra.

image

Depois de introduzires pelo menos um tipo de anedota na tabela ZTIPO, ao seleccionares uma dessas linhas e navegares para a tabela inferior constatarás que por cima das linhas da tabela inferior aparece um cabeçalho com a chave primária da tabela superior que está actualmente a ser considerada. Isto é por causa do tal S no campo “Caracterização actualização para campo visão” na vista de actualização da tabela ZANEDOTA. Este é o truque que evita ter de preencher o campo TIPOID na tabela ZANEDOTAS.

Agora é começares para aí a encavalitar tudo o que é tabela.

O Abapinho saúda-vos.

(a imagem do post foi obtida aqui sob a licença Creative Commons).