This is Part 1 in an n part series about using the Pentaho Data Integration tool.

Pentaho DI (PDI) is an ETL tool that allows you to visually process data using a drag and drop interface. Within the series I am going to go through some of the basics then go into some more advanced use cases.

Since I’m new to the blog game, please feel free to leave feedback in the comments section on how I could improve!

Transformations

Transformations are where 99% of the processing magic happens within PDI.

A Transformation is a connection of steps that allow ETL processes to take place on top of data.

It allows rows to be input from a number of input sources, transformed and then output to a number of output sources (text files, databases, etc.). Steps within a transformation are connected by Hops that are one way channels demonstrating the flow of data.

Below is an example of a transformation with two steps and a hop.

Steps

A Step is represented by an icon within the Spoon interface and usually performs a specific task. Each step is like a little function, and these functions can all be joined together to make the full program. Sounds familiar right?

In the above diagram there is a Table Input step that will bring in data from a database table and then a File Output step that will allow the data to be written to a file in a user specified location and format.

Important characteristics:

Step names must be unique within a transformation Most steps can both read and write data (there are a few exceptions) Steps can pass data to one or more other steps through hops (discussed next). Most steps can have multiple outgoing hops When a transformation is run, one or more copies of each step are initialised and run in their own thread - all these steps run simultaneously (or as parallel as possible). Each step has a set of features that define its functionality.

Hops

A Hop defines the data flow between two steps and is represented by an arrow.

A hop can take many forms such as:

Always flow data to the next step (default for most steps). Flow data if true or false - some steps can filter data in different directions based on a condition, this is represented in the image below for example, by the Filter Rows step using Green and Red arrows for True, False conditions respectively.

Below is an example of a Hops after filtering (notice the difference to the first image)

Running your first transformation

The Hello world of PDI:

Open PDI and go to File > New > Transformation On the left go the the Input folder and Drag and drop a Data Grid step onto the canvas On the left go to the Utility folder and drag and drop a Write to log step to the right of the Data Grid step. Join the two steps together with a hop by holding SHIFT, click and hold on the Data Grid and drag the mouse over to the Write to log step then let go. Double click on the Data Grid step, now we are going to insert some data. A Data Grid is like an excel sheet or a static table. In the meta tab we can define the columns for our grid, make a column called Hello of type String. Within the Data Grid step, now go to the Data tab. You should see the Hello column. Insert some data in this column by clicking and typing within the grid. Save the transformation by clicking save (top left) Now lets run it! Hit the green play button towards the top of the canvas. Once its run, you should see an Execution Results panel display at the bottom of the page with a bunch of tabs. For now, select the Logging tab. You should see your text displayed. The log will tell you that name of the step outputting the message, the column name (Hello) and the text you entered.

Summary

Well thats it for this first part. Short, sweet and simple!

There are a vast number of different steps that would take an age to explain but are mostly really intuitive to use with the small amount of knowledge displayed in this post. Pentaho provide a set of documentation for each step that is very useful too.

Let me know if you want to see more of this :)

If you enjoyed this, please check out PART 2