Published on Aug 12,2014
5.5K Views
Email Post

What is Pig and Pig Latin?

Pig is an open-source high level data flow system. It provides a simple language called Pig Latin, for queries and data manipulation, which are then compiled in to MapReduce jobs that run on Hadoop.

Pig is important as companies like Yahoo, Google and Microsoft are collecting huge amounts of data sets in the form of click streams, search logs and web crawls. Pig is also used in some form of ad-hoc processing and analysis of all the information.

Why Do you Need Pig?

  • It’s easy to learn, especially if you’re familiar with SQL.
  • Pig’s multi-query approach reduces the number of times data is scanned. This means 1/20th the lines of code and 1/16th the development time when compared to writing raw MapReduce.

  • Performance of Pig is in par with raw MapReduce
  • Pig provides data operations like filters, joins, ordering, etc. and nested data types like tuples, bags, and maps, that are missing from MapReduce.
  • Pig Latin is easy to write and read.

Why was Pig Created?

Pig was originally developed by Yahoo in 2006, for researchers to have an ad-hoc way of creating and executing MapReduce jobs on very large data sets. It was created to reduce the development time through its multi-query approach. Pig is also created for professionals from non-Java background, to make their job easier.

Where Should Pig be Used?

Pig can be used under following scenarios:

  • When data loads are time sensitive.
  • When processing various data sources.
  • When analytical insights are required through sampling.

Where Not to Use Pig?

  • In places where the data is completely unstructured, like video, audio and readable text.
  • In places where time constraints exist, as Pig is slower than MapReduce jobs.
  • In places where more power is required to optimize the codes.

Applications of Apache Pig:

  • Processing of web logs.
  • Data processing for search platforms.
  • Support for Ad-hoc queries across large data sets.
  • Quick prototyping of algorithms for processing large data sets.

How Yahoo! Uses Pig:

Yahoo uses Pig for the following purpose:

  • In Pipelines – To bring logs from its web servers, where these logs undergo a cleaning step to remove bots, company interval views and clicks.
  • In Research – To quickly write a script to test a theory. Pig Integration makes it easy for the researchers to take a Perl or Python script and run it against a huge data set.

Use Case of Pig in Healthcare Domain:

Pig Use Case in Healthcare

The above diagram gives a clear, step by step explanation of how the data flows through Sqoop, HDFS and Pig script.

Comparing MapReduce and Pig using Weather Data:

Comparing MapReduce and Pig using Weather Data

Source: ftp://ftp.ncdc.noaa.gov/pub/data/uscrn/products/daily01/

Basic Program Structure of Pig:

Basic Program Structure of Pig

Source: Pig Wiki

Here’s the hierarchy of Pig’s program structure:

  • Script – Pig Can run a file script that contains Pig Commands. Eg: pig script .pig runs the command in the local file script.pig
  • Grunt – It is an interactive shell for running Pig commands. It is also possible to run pig scripts from within Grunts using run and exec.
  • Embedded – Can run Pig programs from Java, much like you can use JDBC to run SQL programs from Java.

Components of Pig:

Components of Pig

What is Pig Latin Program?

Pig Latin program is made up of a series of operations or transformations that are applied to the input data to produce output.  The job of Pig is to convert the transformations in to a series of MapReduce jobs.

Basic Types of Data Models in Pig:

Pig comprises of 4 basic types of data models. They are as follows:

  • Atom –  It is a simple atomic data value. It is stored as a string but can be used as either a string or a number
  • Tuple – An ordered set of fields
  • Bag – An collection of tuples.
  • Map –  set of key value pairs.

Types of Data Models in Pig

Got a question for us? Mention them in the comments section and we will get back to you.

Related Posts:

Apache Pig UDF – Eval, Aggregate &  Filter Functions

Operators in Apache Pig – Relational Operators

Big Data and Hadoop Training

About Author
edureka
Published on Aug 12,2014

Share on

Browse Categories

Comments
2 Comments