Conversión de datos en un mensaje

Puede convertir datos de un formato a otro.

Acerca de esta tarea

Por ejemplo, si los elementos se conocen en un mensaje por los nombres y en otro mensaje por los números, es necesario convertir los datos. Por ejemplo:

Type Name          Type Code

Confectionary      2000
Newspapers         3000
Hardware           4000

Observe el mensaje de entrada siguiente:

<Data>
  <Items>
    <Item>
      <Cat>1000</Cat>
      <Description>Milk Chocolate Bar</Description>
      <Type>Confectionary</Type>
    </Item>
    <Item>
      <Cat>1001</Cat>
      <Description>Daily Newspaper</Description>
      <Type>NewsPapers</Type>
    </Item>
    <Item>
      <Cat>1002</Cat>
      <Description>Kitchen Sink</Description>
      <Type>Hardware</Type>
    </Item>
  </Items>
  <TranslateTable>
    <Translate>
      <Name>Confectionary</Name>
      <Number>2000</Number>
    </Translate>
    <Translate>
      <Name>NewsPapers</Name>
      <Number>3000</Number>
    </Translate>
    <Translate>
      <Name>Hardware</Name>
      <Number>4000</Number>
    </Translate>
  </TranslateTable>
</Data>

Este mensaje tiene dos secciones; la primera sección es una lista de elementos en la que cada elemento tiene un número de catálogo y un tipo; la segunda sección es una tabla para conversión entre nombres de tipo descriptivo y códigos de tipo numérico. Incluya un nodo Compute con la transformación siguiente:

SET OutputRoot.XMLNS.Result.Items.Item[] = 
   (SELECT M.Cat, M.Description, T.Number As Type
     FROM 
       InputRoot.XMLNS.Data.Items.Item[]               As M,
       InputRoot.XMLNS.Data.TranslateTable.Translate[] As T
     WHERE M.Type = T.Name
   );

Se genera el mensaje de salida siguiente:

<Result>
  <Items>
    <Item>
      <Cat>1000</Cat>
      <Description>Milk Chocolate Bar</Description>
      <Type>2000</Type>
    </Item>
    <Item>
      <Cat>1001</Cat>
      <Description>Daily Newspaper</Description>
      <Type>3000</Type>
    </Item>
    <Item>
      <Cat>1002</Cat>
      <Description>Kitchen Sink</Description>
      <Type>4000</Type>
    </Item>
  </Items>
</Result>

En el resultado, cada nombre de tipo se ha convertido a su código correspondiente. En este ejemplo, tanto los datos como la tabla de conversión estaban en el mismo árbol de mensajes aunque esto no es un requisito. Por ejemplo, la tabla de conversión se puede codificar en una base de datos, o se puede haber configurado en LocalEnvironment mediante un nodo Compute anterior.