Function Name |
Right | ||||
Category |
String | ||||
Icon |
|||||
Description |
Retrieve right-most section of a String to a particular length | ||||
Inputs |
|
||||
Outputs |
|
||||
Properties |
|
The Data Mapper String Right function retrieves the right-most section of an input String, with the length also specified as input. In other words, the Right function retrieves the last n characters in the input String, creating a substring containing these characters. The Right function is useful if your target data model involves size restrictions, allowing you to limit the length of particular mapped String items. To apply the String Right transform function, use the following process:
Create a new Data Mapper file, dragging your XML data source and targets into the editor area. For this example we are using product_source.xsd, an XML Schema Definition inferred from the following source:
Source XML |
Copy Code
|
---|---|
<catalogue> <product> <name>Kitchen Chair</name> <category>Furniture</category> <description>This lovely chair has lots of fantastic qualities ag65d4hn78</description> </product> <product> <name>Table Lamp</name> <category>Lighting</category> <description>This beautiful lamp is a very special item h76gfr45v2</description> </product> </catalogue> |
For our target schema we will be using product_target.xsd, inferred from the following XML:
Target XML |
Copy Code
|
---|---|
<goods> <item category="Electrical"> <item_name>Toaster</item_name> <item_overview>jkg7jh543d</item_overview> </item> <item category="Gardening"> <item_name>Shovel</item_name> <item_overview>nj87hg10kj</item_overview> </item> </goods> |
The data models produce for a retail service. For demonstration, let's assume that the "description" item in the input contains a code as its final 10 characters - this code is all we want to map to the output Schema, perhaps to use it as a reference within this or another data source. Here is the Data Mapper with Source and Target imported:
Let's drag the String Right function from the Component Palette into the mapping area:
The String Right function takes two inputs and gives a single output. The String input should be connected to the source text String item to retrieve the result text from. The Length input requires a number input indicating the length of the desired right String section. The Right function output should be connected to the target item in the XML Writer or another component. First connect the "description" item in the XML Reader to the String input of the Right function:
Next connect the Right output to the "item_overview" item in the XML Writer:
Now we need to specify the length of the desired right String portion. To do this, we need a Constant Value. Drag one from the Data Type section in the Component Palette onto the mapping area:
We need to specify the value we want the Constant to have. To do so, right-click it and choose Show Properties. Select one of the integer types from the drop-down Data Type menu and enter your chosen number in the Value field.
For this example we are limiting the output String to the last 10 characters of the input String. Connect the Constant output to the Right function Length input:
Now when the source item is mapped to the target item the values will be restricted to the 10 right-most characters.
Finally let's make the remaining input and output connections:
We can now execute the transform by pressing Shift-F5 or the Execute button (). The transform is applied and the file we selected as output opens in the editor:
Output XML |
Copy Code
|
---|---|
<goods> <item category="Furniture"> <item_name>Kitchen Chair</item_name> <item_overview>ag65d4hn78</item_overview> </item> <item category="Lighting"> <item_name>Table Lamp</item_name> <item_overview>h76gfr45v2</item_overview> </item> </goods> |
The input element value has been limited to the last 10 characters as part of the mapping process. Often, XML mapping involves converting from legacy systems to new applications in which you may have restrictions in terms of storage space. The Right function can therefore be useful for both human-readable and non-human-readable Strings comprising data items in which you do not need all characters to be preserved when mapping to a new model.
This is a scalar function so the standard rules apply if multiple values are presented to one or more inputs.