Friday, October 26, 2018

SQL Interview Question with Answers




1. What is the SQL server query execution sequence?
○ FROM -> goes to Secondary files via primary file
○ WHERE -> applies filter condition (non-aggregate column)
○ SELECT -> dumps data in tempDB system database
○ GROUP BY -> groups data according to grouping predicate
○ HAVING -> applies filter condition (aggregate function)
○ ORDER BY -> sorts data ascending/descending


2. What is Normalization?
  • Step by step process to reduce the degree of data redundancy.
  • Breaking down one big flat table into multiple table based on normalization rules.
  • Optimizing the memory but not in term of performance.
  • Normalization will get rid of insert, update and delete anomalies.
  • Normalization will improve the performance of the delta operation (aka. DML operation); UPDATE, INSERT, DELETE
  • Normalization will reduce the performance of the read operation; SELECT
3. What are the three degrees of normalization and how is normalization done in each degree?
1NF:
A table is in 1NF when:
  • All the attributes are single-valued.
  • With no repeating columns (in other words, there cannot be two different columns with the same information).
  • With no repeating rows (in other words, the table must have a primary key).
  • All the composite attributes are broken down into its minimal component.
  • There should be SOME (full, partial, or transitive) kind of functional dependencies between non-key and key attributes.
  • 99% of times, it’s usually 1NF.
2NF:
A table is in 2NF when:
● It is in 1NF.
● There should not be any partial dependencies so they must be removed if they exist.

3NF:
A table is in 3NF when:
● It is in 2NF.
● There should not be any transitive dependencies so they must be removed if they exist.

BCNF:
■ A stronger form of 3NF so it is also known as 3.5NF
■ We do not need to know much about it. Just know that here you compare between a prime attribute and a prime attribute and a non-key attribute and a non-key attribute.

4. What are the different database objects ?
There are total seven database objects (6 permanent database object + 1 temporary database object)
Permanent DB objects
    ●     Table
    ●     Views
    ●     Stored procedures
    ●     User-defined Functions
    ●     Triggers
    ●     Indexes
Temporary DB object
    ●     Cursors

5. What is collation?
Collation is defined as set of rules that determine how character data can be sorted and compared. This can be used to compare A and, other language characters and also depends on the width of the characters.

ASCII value can be used to compare these character data.

6. What is a constraint and what are the seven constraint ?
Constraint: something that limits the flow in a database.
○ 1. Primary key
○ 2. Foreign key
○ 3. Check
        ■ Ex: check if the salary of employees is over 40,000
○ 4. Default
        ■ Ex: If the salary of an employee is missing, place it with
the default value.
○ 5. Nullability
        ■ NULL or NOT NULL
○ 6. Unique Key
○ 7. Surrogate Key
        ■ mainly used in data warehouse

7. What is a Surrogate Key ?
  • ‘Surrogate’ means ‘Substitute’.
  • Surrogate key is always implemented with a help of an identity column.
  • Identity column is a column in which the value are automatically generated by a SQL Server based on the seed value and incremental value.
  • Identity columns are ALWAYS INT, which means surrogate keys must be INT.
  • Identity columns cannot have any NULL and cannot have repeated values.
  • Surrogate key is a logical key.
8. What is a derived column , hows does it work , how it affects the performance of a database and how can it be improved?
  • The Derived Column a new column that is generated on the fly by applying expressions to transformation input columns.
Ex: FirstName + ‘ ‘ + LastName AS ‘Full name’
  • Derived column affect the performances of the data base due to the creation of a temporary new column.
  • Execution plan can save the new column to have better performance next time.
9. What is a Transaction?
○ It is a set of TSQL statement that must be executed together as a single logical unit.
○ Has ACID properties:
  • Atomicity: Transactions on the DB should be all or nothing. So transactions make sure that any operations in the transaction happen or none of them do.
  • Consistency: Values inside the DB should be consistent with the constraints and integrity of the DB before and after a transaction has completed or failed.
  • Isolation: Ensures that each transaction is separated from any other transaction occurring on the system.
  • Durability: After successfully being committed to the RDMBS system the transaction will not be lost in the event of a system failure or error.
○ Actions performed on explicit transaction:
  • BEGIN TRANSACTION: marks the starting point of an explicit transaction for a connection.
  • COMMIT TRANSACTION (transaction ends): used to end an transaction successfully if no errors were encountered. All DML changes made in the transaction become permanent.
  • ROLLBACK TRANSACTION (transaction ends): used to erase a transaction which errors are encountered. All DML changes made in the transaction are undone.
  • SAVE TRANSACTION (transaction is still active): sets a savepoint in a transaction. If we roll back, we can only rollback to the most recent savepoint. Only one save point is possible per transaction. However, if you nest Transactions within a Master Trans, you may put Save points in each nested Tran. That is how you create more than one Save point in a Master Transaction.
10. What are the differences between OLTP and OLAP?
  • OLTP stands for Online Transactional Processing
  • OLAP stands for Online Analytical Processing
OLTP:
Normalization Level: highly normalized
Data Usage : Current Data (Database)
Processing : fast for delta operations (DML)
Operation : Delta operation (update, insert, delete) aka DML
Terms Used : table, columns and relationships

OLAP:
Normalization Level: highly denormalized
Data Usage : historical Data (Data warehouse)
Processing : fast for read operations
Operation : read operation (select)
Terms Used : dimension table, fact table

11. How do you copy just the structure of a table?
SELECT * INTO NewDB.TBL_Structure
FROM OldDB.TBL_Structure
WHERE 1=0 -- Put any condition that does not make any sense.

12.What are the different types of Joins?
○ INNER JOIN: Gets all the matching records from both the left and right tables based on joining columns.
○ LEFT OUTER JOIN: Gets all non-matching records from left table & AND one copy of matching records from both the tables based on the joining columns.
○ RIGHT OUTER JOIN: Gets all non-matching records from right table & AND one copy of matching records from both the tables based on the joining columns.
○ FULL OUTER JOIN: Gets all non-matching records from left table & all non-matching records from right table & one copy of matching records from both the tables.
○ CROSS JOIN: returns the Cartesian product.

13. What are the different types of Restricted Joins?
○ SELF JOIN: joining a table to itself
○ RESTRICTED LEFT OUTER JOIN: gets all non-matching records from
left side
○ RESTRICTED RIGHT OUTER JOIN - gets all non-matching records from
right side
○ RESTRICTED FULL OUTER JOIN - gets all non-matching records from
left table & gets all non-matching records from right table.

14. What is a sub-query?
○ It is a query within a query
○ Syntax:
SELECT <column_name> FROM <table_name>
WHERE <column_name> IN/NOT IN
(
<another SELECT statement>
)
○ Everything that we can do using sub queries can be done using Joins, but anything that we can do using Joins may/may not be done using Subquery.
○ Sub-Query consists of an inner query and outer query. Inner query is a SELECT statement the result of which is passed to the outer query. The outer query can be SELECT, UPDATE, DELETE. The result of the inner query is generally used to filter what we select from the outer query.
○ We can also have a subquery inside of another subquery and so on. This is called a nested Subquery. Maximum one can have is 32 levels of nested Sub-Queries.

15. What are the SET Operators?
○ SQL set operators allows you to combine results from two or more
SELECT statements.
○ Syntax:
SELECT Col1, Col2, Col3 FROM T1
<SET OPERATOR>
SELECT Col1, Col2, Col3 FROM T2
○ Rule 1: The number of columns in first SELECT statement must be same as the number of columns in the second SELECT statement.
○ Rule 2: The metadata of all the columns in first SELECT statement MUST be exactly same as the metadata of all the columns in second SELECT statement accordingly.
○ Rule 3: ORDER BY clause do not work with first SELECT statement.
○ UNION, UNION ALL, INTERSECT, EXCEPT

16. What is a derived table?
○ SELECT statement that is given an alias name and can now be treated as a virtual table and operations like joins, aggregations, etc. can be performed on it like on an actual table.
○ Scope is query bound, that is a derived table exists only in the query in which it was defined.
SELECT temp1.SalesOrderID, temp1.TotalDue FROM
(SELECT TOP 3 SalesOrderID, TotalDue FROM Sales.SalesOrderHeader ORDER BY TotalDue DESC) AS temp1
LEFT OUTER JOIN
(SELECT TOP 2 SalesOrderID, TotalDue FROM Sales.SalesOrderHeader ORDER BY TotalDue DESC) AS temp2
ON temp1.SalesOrderID = temp2.SalesOrderID WHERE temp2.SalesOrderID IS NULL

17. What is a View?
○ Views are database objects which are virtual tables whose structure is defined by underlying SELECT statement and is mainly used to implement security at rows and columns levels on the base
table.
○ One can create a view on top of other views.
○ View just needs a result set (SELECT statement).
○ We use views just like regular tables when it comes to query writing. (joins, subqueries, grouping....)
○ We can perform DML operations (INSERT, DELETE, UPDATE) on a view. It actually affects the underlying tables only those columns can be affected which are visible in the view.

18. What are the types of views?
1. Regular View: 
It is a type of view in which you are free to make any DDL changes on the underlying table.
-- create a regular view
CREATE VIEW v_regular AS SELECT * FROM T1

2. Schemabinding View: 
It is a type of view in which the schema of the view (column) are physically bound to the schema of the underlying table. We are not allowed to perform any DDL changes
to the underlying table for the columns that are referred by the schemabinding view structure.
■ All objects in the SELECT query of the view must be specified in two part naming conventions
(schema_name.tablename).
■ You cannot use * operator in the SELECT query inside the view (individually name the columns)
■ All rules that apply for regular view.
CREATE VIEW v_schemabound WITH SCHEMABINDING AS
SELECT ID, Name
FROM dbo.T2 -- remember to use two part naming convention

3. Indexed View:

19. What is an Indexed View?
○ It is technically one of the types of View, not Index.
○ Using Indexed Views, you can have more than one clustered index on the same table if needed.
○ All the indexes created on a View and underlying table are shared by Query Optimizer to select the best way to execute the query.
○ Both the Indexed View and Base Table are always in sync at any given point.
○ Indexed Views cannot have NCI-H, always NCI-CI, therefore a duplicate set of the data will be created.

20. What does WITH CHECK do?
○ WITH CHECK is used with a VIEW.
○ It is used to restrict DML operations on the view according to search predicate (WHERE clause) specified creating a view.
○ Users cannot perform any DML operations that do not satisfy the conditions in WHERE clause while creating a view.
○ WITH CHECK OPTION has to have a WHERE clause.

21. What is a RANKING function and what are the four RANKING functions?
  • Ranking functions are used to give some ranking numbers to each row in a dataset based on some ranking functionality.
  • Every ranking function creates a derived column which has integer value.
  • Different types of RANKING function:
  • ROW_NUMBER(): assigns an unique number based on the ordering starting with 1. Ties will be given different ranking positions.
  • RANK(): assigns an unique rank based on value. When the set of ties ends, the next ranking position will consider how many tied values exist and then assign the next value a new ranking with consideration the number of those previous ties. This will make the ranking position skip placement.
  • position numbers based on how many of the same values occurred (ranking not sequential).
  • DENSE_RANK(): same as rank, however it will maintain its consecutive order nature regardless of ties in values; meaning if five records have a tie in the values, the next ranking will begin with the next ranking position.
  • Syntax:
<Ranking Function>() OVER(condition for ordering) -- always have to have an OVER clause

Ex:
SELECT SalesOrderID,
SalesPersonID,
TotalDue,
ROW_NUMBER() OVER(ORDER BY TotalDue),
RANK() OVER(ORDER BY TotalDue),
DENSE_RANK() OVER(ORDER BY TotalDue)
FROM Sales.SalesOrderHeader

■ NTILE(n): Distributes the rows in an ordered partition into a specified number of groups.

22. What is PARTITION BY?
○ Creates partitions within the same result set and each partition gets its own ranking. That is, the rank starts from 1 for each partition.
○ Ex:
SELECT *, DENSE_RANK() OVER(PARTITION BY Country ORDER BY
Sales DESC) AS DenseRank FROM SalesInfo

23. What is Temporary Table and what are the two types of it?
○ They are tables just like regular tables but the main difference is its scope.
○ The scope of temp tables is temporary whereas regular tables permanently reside.
○ Temporary table are stored in tempDB.
○ We can do all kinds of SQL operations with temporary tables just like regular tables like JOINs, GROUPING, ADDING CONSTRAINTS, etc.
○ Two types of Temporary Table
■ Local
  • #LocalTempTableName -- single pound sign
  • Only visible in the session in which they are created.
  • It is session-bound.
■ Global
  • ##GlobalTempTableName -- double pound sign
  • Global temporary tables are visible to all sessions after they are created, and are deleted when the session in which they were created in is disconnected.
  • It is last logged-on user bound. In other words, a global temporary table will disappear when the last user on the session logs off.
24. Explain Variables ..?
○ Variable is a memory space (place holder) that contains a scalar value EXCEPT table variables, which is 2D data.
○ Variable in SQL Server are created using DECLARE Statement.
○ Variables are BATCH-BOUND.
○ Variables that start with @ are user-defined variables.

25. Explain Dynamic SQL (DSQL). ?
  • Dynamic SQL refers to code/script which can be used to operate on different data-sets based on some dynamic values supplied by front-end applications. It can be used to run a template SQL query against different tables/columns/conditions.
  • Declare variables: which makes SQL code dynamic.
  • Main disadvantage of D-SQL is that we are opening SQL Tool for SQL Injection attacks.
  • You should build the SQL script by concatenating strings and variable.
26. What is SQL Injection Attack?
○ Moderator’s definition: when someone is able to write a code at the front end using DSQL, he/she could use malicious code to drop, delete, or manipulate the database. There is no perfect protection from it but we can check if there is certain commands such as 'DROP' or 'DELETE' are included in the command line.
○ SQL Injection is a technique used to attack websites by inserting SQL code in web entry fields.

27. What is SELF JOIN?
○ JOINing a table to itself
○ When it comes to SELF JOIN, the foreign key of a table points to its primary key.
○ Ex: Employee(Eid, Name, Title, Mid)
○ Know how to implement it!!!

28. What is Correlated Subquery?
○ It is a type of subquery in which the inner query depends on the outer query. This means that that the subquery is executed repeatedly, once for each row of the outer query.
○ In a regular subquery, inner query generates a resultset that is independent of the outer query.
○ Ex:
SELECT *
FROM HumanResources.Employee E
WHERE 5000 IN (SELECT S.Bonus
FROM Sales.SalesPerson S
WHERE S.SalesPersonID = E.EmployeeID)
○ The performance of Correlated Subquery is very slow because its inner query depends on the outer query. So the inner subquery goes through every single row of the result of the outer subquery.

29. What is the difference between Regular Subquery and Correlated Subquery?
○ Based on the above explanation, an inner subquery is independent from its outer subquery in Regular Subquery. On the other hand, an inner subquery depends on its outer subquery in Correlated Subquery.

30. What are the differences between DELETE and TRUNCATE .?
Delete:
  • DML statement that deletes rows from a table and can also specify rows using a WHERE clause.
  • Logs every row deleted in the log file.
  • Slower since DELETE records every row that is deleted.
  • DELETE continues using the earlier max value of the identity column.
  • Can have triggers on DELETE.
Truncate:
  • DDL statement that wipes out the entire table and you cannot delete specific rows.
  • Does minimal logging, minimal as not logging everything. TRUNCATE will remove the pointers that point to their pages, which are deallocated.
  • Faster since TRUNCATE does not record into the log file.
  • TRUNCATE resets the identity column.
  • Cannot have triggers on TRUNCATE.
31. What are the three different types of Control Flow statements?
1. WHILE
2. IF-ELSE
3. CASE

32. What is Table Variable? Explain its advantages and disadvantages.?
○ If we want to store tabular data in the form of rows and columns into a variable then we use a table variable.
○ It is able to store and display 2D data (rows and columns).
○ We cannot perform DDL (CREATE, ALTER, DROP).

Advantages:
■ Table variables can be faster than permanent tables.
■ Table variables need less locking and logging resources.

Disadvantages:
■ Scope of Table variables is batch bound.
■ Table variables cannot have constraints.
■ Table variables cannot have indexes.
■ Table variables do not generate statistics.
■ Cannot ALTER once declared (Again, no DDL statements).

33. What are the differences between Temporary Table and Table Variable?
Temporary Table:
  • It can perform both DML and DDL Statement.
  • Session bound Scope
  • Syntax CREATE TABLE #temp
  • Have indexes
Table Variable:
  • Can perform only DML, but not DDL
  • Batch bound scope
  • DECLARE @var TABLE(...)
  • Cannot have indexes
34. What is Stored Procedure (SP)?
  • It is one of the permanent DB objects that is precompiled set of TSQL statements that can accept and return multiple variables.
  • It is used to implement the complex business process/logic. In other words, it encapsulates your entire business process.
  • Compiler breaks query into Tokens. And passed on to query optimizer. Where execution plan is generated the very 1st time when we execute a stored procedure after creating/altering it and same execution plan is utilized for subsequent executions.
  • Database engine runs the machine language query and execute the code in 0's and 1's.
  • When a SP is created all Tsql statements that are the part of SP are pre-compiled and execution plan is stored in DB which is referred for following executions.
  • Explicit DDL requires recompilation of SP's.
35. What are the four types of SP?
  • System Stored Procedures (SP_****): built-in stored procedures that were created by Microsoft.
  • User Defined Stored Procedures: stored procedures that are created by users. Common naming convention (usp_****)
  • CLR (Common Language Runtime): stored procedures that are implemented as public static methods on a class in a Microsoft .NET Framework assembly.
  • Extended Stored Procedures (XP_****): stored procedures that can be used in other platforms such as Java or C++.
36. Explain the Types of SP..?
○ SP with no parameters:
○ SP with a single input parameter:
○ SP with multiple parameters:
○ SP with output parameters: 
Extracting data from a stored procedure based on an input parameter and outputting them using output variables.
○ SP with RETURN statement (the return value is always single and integer value)

37. What are the characteristics of SP?
○ SP can have any kind of DML and DDL statements.
○ SP can have error handling (TRY ... CATCH).
○ SP can use all types of table.
○ SP can output multiple integer values using OUT parameters, but can return only one scalar INT value.
○ SP can take any input except a table variable.
○ SP can set default inputs.
○ SP can use DSQL.
○ SP can have nested SPs.
○ SP cannot output 2D data (cannot return and output table variables).
○ SP cannot be called from a SELECT statement. It can be executed using only a EXEC/EXECUTE statement.

38. What are the advantages of SP?
○ Precompiled code hence faster.
○ They allow modular programming, which means it allows you to break down a big chunk of code into smaller pieces of codes. This way the code will be more readable and more easier to manage.
○ Reusability.
○ Can enhance security of your application. Users can be granted permission to execute SP without having to have direct permissions on the objects referenced in the procedure.
○ Can reduce network traffic. An operation of hundreds of lines of code can be performed through single statement that executes the code in procedure rather than by sending hundreds of lines of
code over the network.
○ SPs are pre-compiled, which means it has to have an Execution Plan so every time it gets executed after creating a new Execution Plan, it will save up to 70% of execution time. Without it, the SPs are just like any regular TSQL statements.

39. What is User Defined Functions (UDF)?
○ UDFs are a database object and a precompiled set of TSQL statements that can accept parameters, perform complex business calculation, and return of the action as a value.
○ The return value can either be single scalar value or result set-2D data.
○ UDFs are also pre-compiled and their execution plan is saved.
○ PASSING INPUT PARAMETER(S) IS/ARE OPTIONAL, BUT MUST HAVE A RETURN STATEMENT.

40. What is the difference between Stored Procedure and UDF?
Stored Procedure:
  • may or may not return any value. When it does, it must be scalar INT.
  • Can create temporary tables.
  • Can have robust error handling in SP (TRY/CATCH, transactions).
  • Can include any DDL and DML statements.
UDF:
  • must return something, which can be either scalar/table valued.
  • Cannot access to temporary tables.
  • No robust error handling available in UDF like TRY/ CATCH and transactions.
  • Cannot have any DDL and can do DML only with table variables.
41. What are the types of UDF?
1. Scalar
Deterministic UDF: UDF in which particular input results in particular output. In other words, the output depends on the input.
Non-deterministic UDF: UDF in which the output does not directly depend on the input.

2. In-line UDF: 
UDFs that do not have any function body(BEGIN...END) and has only a RETURN statement. In-line UDF must return 2D data.

3. Multi-line or Table Valued Functions: 
It is an UDF that has its own function body (BEGIN ... END) and can have multiple SQL
statements that return a single output. Also must return 2D data in the form of table variable.

42. What is the difference between a nested UDF and recursive UDF?
○ Nested UDF: calling an UDF within an UDF
○ Recursive UDF: calling an UDF within itself

43. What is a Trigger?
○ It is a precompiled set of TSQL statements that are automatically executed on a particular DDL, DML or log-on event.
○ Triggers do not have any parameters or return statement.
○ Triggers are the only way to access to the INSERTED and DELETED tables (aka. Magic Tables).
○ You can DISABLE/ENABLE Triggers instead of DROPPING them:
DISABLE TRIGGER <name> ON <table/view name>/DATABASE/ALL SERVER
ENABLE TRIGGER <name> ON <table/view name>/DATABASE/ALL SERVER

44.What are the types of Triggers?
1. DML Trigger
  • DML Triggers are invoked when a DML statement such as INSERT, UPDATE, or DELETE occur which modify data in a specified TABLE or VIEW.
  • A DML trigger can query other tables and can include complex TSQL statements.
  • They can cascade changes through related tables in the database.
  • They provide security against malicious or incorrect DML operations and enforce restrictions that are more complex than those defined with constraints.
2. DDL Trigger
  • Pretty much the same as DML Triggers but DDL Triggers are for DDL operations.
  • DDL Triggers are at the database or server level (or scope).
  • DDL Trigger only has AFTER. It does not have INSTEAD OF.
3. Logon Trigger
  • Logon triggers fire in response to a logon event.
  • This event is raised when a user session is established with an instance of SQL server.
  • Logon TRIGGER has server scope.
45. What are ‘inserted’ and ‘deleted’ tables (aka. magic tables)?
○ They are tables that you can communicate with between the external code and trigger body.
○ The structure of inserted and deleted magic tables depends upon the structure of the table in a DML statement.
○ UPDATE is a combination of INSERT and DELETE, so its old record will be in the deleted table and its new record will be stored in the inserted table.

46. What are some String functions to remember?
LEN(string): returns the length of string.
UPPER(string) & LOWER(string): returns its upper/lower string
LTRIM(string) & RTRIM(string): remove empty string on either ends of the string
LEFT(string): extracts a certain number of characters from left side of the string
RIGHT(string): extracts a certain number of characters from right side of the string
SUBSTRING(string, starting_position, length): returns the sub string of the string
REVERSE(string): returns the reverse string of the string
Concatenation: Just use + sign for it
REPLACE(string, string_replaced, string_replace_with)

47. What are the three different types of Error Handling?
1. TRY CATCH
The first error encountered in a TRY block will direct you to its CATCH block ignoring the rest of the code in the TRY block will generate an error or not.

2. @@error
stores the error code for the last executed SQL statement.
If there is no error, then it is equal to 0.
If there is an error, then it has another number (error code).

3. RAISERROR() function
A system defined function that is used to return messages back to applications using the same format which SQL uses for errors or warning message.

48. Explain about Cursors ..?
○ Cursors are a temporary database object which are used to loop through a table on row-by-row basis.
There are five types of cursors:
■ 1. Static: shows a static view of the data with only the changes done by session which opened the cursor.
■ 2. Dynamic: shows data in its current state as the cursor moves from record-to-record.
■ 3. Forward Only: move only record-by-record
■ 4. Scrolling: moves anywhere.
■ 5. Read Only: prevents data manipulation to cursor data set.

49. What is the difference between Table scan and seek ?
○ Scan: going through from the first page to the last page of an offset by offset or row by row.
○ Seek: going to the specific node and fetching the information needed.
○ ‘Seek’ is the fastest way to find and fetch the data. So if you see your Execution Plan and if all of them is a seek, that means it’s optimized.

50. Why are the DML operations are slower on Indexes?
○ It is because the sorting of indexes and the order of sorting has to be always maintained.
○ When inserting or deleting a value that is in the middle of the range of the index, everything has to be rearranged again. It cannot just insert a new value at the end of the index.

51. What is a heap (table on a heap)?
○ When there is a table that does not have a clustered index, that means the table is on a heap.
○ Ex: Following table ‘Emp’ is a table on a heap.
SELECT * FROM Emp WHERE ID BETWEEN 2 AND 4 -- This will do scanning.

52. What is the architecture in terms of a hard disk, extents and pages?
○ A hard disk is divided into Extents.
○ Every extent has eight pages.
○ Every page is 8KBs ( 8060 bytes).

53. What are the nine different types of Indexes?
○ 1. Clustered
○ 2. Non-clustered
○ 3. Covering
○ 4. Full Text Index
○ 5. Spatial
○ 6. Unique
○ 7. Filtered
○ 8. XML
○ 9. Index View

54. What is a Clustering Key?
○ It is a column on which I create any type of index is called a Clustering Key for that particular index.

55. Explain about a Clustered Index.?
○ Unique Clustered Indexes are automatically created when a PK is created on a table.
○ But that does not mean that a column is a PK only because it has a Clustered Index.
○ Clustered Indexes store data in a contiguous manner. In other words, they cluster the data into a certain spot on a hard disk continuously.
○ The clustered data is ordered physically.
○ You can only have one CI on a table.

56. What happens when Clustered Index is created?
○ First, a B-Tree of a CI will be created in the background.
○ Then it will physically pull the data from the heap memory and physically sort the data based on the clustering key.
○ Then it will store the data in the leaf nodes.
○ Now the data is stored in your hard disk in a continuous manner.

57. What are the four different types of searching information in a table?
○ 1. Table Scan -> the worst way
○ 2. Table Seek -> only theoretical, not possible
○ 3. Index Scan -> scanning leaf nodes
○ 4. Index Seek -> getting to the node needed, the best way

58. What is Fragmentation .?
○ Fragmentation is a phenomenon in which storage space is used inefficiently.
○ In SQL Server, Fragmentation occurs in case of DML statements on a table that has an index.
○ When any record is deleted from the table which has any index, it creates a memory bubble which causes fragmentation.
○ Fragmentation can also be caused due to page split, which is the way of building B-Tree dynamically according to the new records coming into the table.
○ Taking care of fragmentation levels and maintaining them is the major problem for Indexes.
○ Since Indexes slow down DML operations, we do not have a lot of indexes on OLTP, but it is recommended to have many different indexes in OLAP.

59. What are the two types of fragmentation?
1. Internal Fragmentation
It is the fragmentation in which leaf nodes of a B-Tree is not filled to its fullest capacity and contains memory bubbles.

2. External Fragmentation
It is fragmentation in which the logical ordering of the pages does not match the physical ordering of the pages on the secondary storage device.

60. What are Statistics?
○ Statistics allow the Query Optimizer to choose the optimal path in getting the data from the underlying table.
○ Statistics are histograms of max 200 sampled values from columns separated by intervals.
○ Every statistic holds the following info:
■ 1. The number of rows and pages occupied by a table’s data
■ 2. The time that statistics was last updated
■ 3. The average length of keys in a column
■ 4. Histogram showing the distribution of data in column

61. What are some optimization techniques in SQL?
1. Build indexes. Using indexes on a table, It will dramatically increase the performance of your read operation because it will allow you to perform index scan or index seek depending on your search predicates and select predicates instead of table scan.
Building non-clustered indexes, you could also increase the performance further.
2. You could also use an appropriate filtered index for your non clustered index because it could avoid performing a key lookup.
3. You could also use a filtered index for your non-clustered index since it allows you to create an index on a particular part of a table that is accessed more frequently than other parts.
4. You could also use an indexed view, which is a way to create one or more clustered indexes on the same table. In that way, the query optimizer will consider even the clustered keys on the indexed views so there might be a possible faster option to execute your query.
5. Do table partitioning. When a particular table as a billion of records, it would be practical to partition a table so that it can increase the read operation performance. Every partitioned
table will be considered as physical smaller tables internally.
6. Update statistics for TSQL so that the query optimizer will choose the most optimal path in getting the data from the underlying table. Statistics are histograms of maximum 200 sample values from columns separated by intervals.
7. Use stored procedures because when you first execute a stored procedure, its execution plan is stored and the same execution plan will be used for the subsequent executions rather than generating an execution plan every time.
8. Use the 3 or 4 naming conventions. If you use the 2 naming convention, table name and column name, the SQL engine will take some time to find its schema. By specifying the schema name or
even server name, you will be able to save some time for the SQL server.
9. Avoid using SELECT *. Because you are selecting everything, it will decrease the performance. Try to select columns you need.
10. Avoid using CURSOR because it is an object that goes over a table on a row-by-row basis, which is similar to the table scan. It is not really an effective way.
11. Avoid using unnecessary TRIGGER. If you have unnecessary triggers, they will be triggered needlessly. Not only slowing the performance down, it might mess up your whole program as well.
12. Manage Indexes using RECOMPILE or REBUILD.
The internal fragmentation happens when there are a lot of data bubbles on the leaf nodes of the b-tree and the leaf nodes are not used to its fullest capacity. By recompiling, you can push the actual data on the b-tree to the left side of the leaf level and push the memory bubble to the right side. But it is still atemporary solution because the memory bubbles will still exist and won’t be still accessed much.
The external fragmentation occurs when the logical ordering of the b-tree pages does not match the physical ordering on the hard disk. By rebuilding, you can cluster them all together, which will solve not only the internal but also the external fragmentation issues. You can check the status of the fragmentation by using Data Management Function, sys.dm_db_index_physical_stats(db_id, table_id, index_id, partition_num, flag), and looking at the columns, avg_page_space_used_in_percent for the internal fragmentation and avg_fragmentation_in_percent for the external fragmentation.
13. Try to use JOIN instead of SET operators or SUB-QUERIES because set operators and sub-queries are slower than joins and you can implement the features of sets and sub-queries using joins.
14. Avoid using LIKE operators, which is a string matching operator but it is mighty slow.
15. Avoid using blocking operations such as order by or derived columns.
16. For the last resort, use the SQL Server Profiler. It generates a trace file, which is a really detailed version of execution plan. Then DTA (Database Engine Tuning Advisor) will take a trace file as its input and analyzes it and gives you the recommendation on how to improve your query further.

62. How do you present the following tree in a form of a table?
A
/ \
B C
/ \ / \
D E F G

CREATE TABLE tree ( node CHAR(1), parentNode CHAR(1), [level] INT)
INSERT INTO tree VALUES ('A', null, 1),
('B', 'A', 2),
('C', 'A', 2),
('D', 'B', 3),
('E', 'B', 3),
('F', 'C', 3),
('G', 'C', 3)

SELECT * FROM tree
Result: 
A NULL 1
B A 2
C A 2
D B 3
E B 3
F C 3
G C 3

63. How do you reverse a string without using REVERSE (‘string’) ?
CREATE PROC rev (@string VARCHAR(50)) AS
BEGIN
DECLARE @new_string VARCHAR(50) = ''
DECLARE @len INT = LEN(@string)
WHILE (@len <> 0)
BEGIN
DECLARE @char CHAR(1) = SUBSTRING(@string, @len, 1)
SET @new_string = @new_string + @char
SET @len = @len - 1
END
PRINT @new_string
END
EXEC rev 'dinesh'

64. What is Deadlock?
○ Deadlock is a situation where, say there are two transactions, the two transactions are waiting for each other to release their locks.
○ The SQL automatically picks which transaction should be killed, which becomes a deadlock victim, and roll back the change for it and throws an error message for it.

65. What is a Fact Table?
The primary table in a dimensional model where the numerical performance measurements (or facts) of the business are stored so they can be summarized to provide information about the history of the operation of an organization.

We use the term fact to represent a business measure. The level of granularity defines the grain of the fact table.

66. What is a Dimension Table?
Dimension tables are highly denormalized tables that contain the textual descriptions of the business and facts in their fact table.
Since it is not uncommon for a dimension table to have 50 to 100 attributes and dimension tables tend to be relatively shallow in terms of the number of rows, they are also called a wide table.
A dimension table has to have a surrogate key as its primary key and has to have a business/alternate key to link between the OLTP and OLAP.

67. What are the types of Measures?
○ Additive: measures that can be added across all dimensions (cost, sales).
○ Semi-Additive: measures that can be added across few dimensions and not with others.
○ Non-Additive: measures that cannot be added across all dimensions (stock rates).

68. What is a Star Schema?
○ It is a data warehouse design where all the dimensions tables in the warehouse are directly connected to the fact table.
○ The number of foreign keys in the fact table is equal to the number of dimensions.
○ It is a simple design and hence faster query.

69. What is a Snowflake Schema?
○ It is a data warehouse design where at least one or more multiple dimensions are further normalized.
○ Number of dimensions > number of fact table foreign keys
○ Normalization reduces redundancy so storage wise it is better but querying can be affected due to the excessive joins that need to be performed.

70. What is granularity?
○ The lowest level of information that is stored in the fact table.
○ Usually determined by the time dimension table.
○ The best granularity level would be per transaction but it would require a lot of memory.

71. What is a Surrogate Key?
○ It is a system generated key that is an identity column with the initial value and incremental value and ensures the uniqueness of the data in the dimension table.
○ Every dimension table must have a surrogate key to identify each record!!!

72. What are some advantages of using the Surrogate Key in a Data Warehouse?
○ 1. Using a SK, you can separate the Data Warehouse and the OLTP: to integrate data coming from heterogeneous sources, we need to differentiate between similar business keys from the OLTP. The
keys in OLTP are the alternate key (business key).
○ 2. Performance: The fact table will have a composite key. If surrogate keys are used, then in the fact table, we will have integers for its foreign keys.
■ This requires less storage than VARCHAR.
■ The queries will run faster when you join on integers rather than VARCHAR.
■ The partitioning done on SK will be faster as these are in sequence.
○ 3. Historical Preservation: A data warehouse acts as a repository of historical data so there will be various versions of the same record and in order to differentiate between them, we need a SK then we can keep the history of data.
○ 4. Special Situations (Late Arriving Dimension): Fact table has a record that doesn’t have a match yet in the dimension table. Surrogate key usage enables the use of such a ‘not found’ record as a SK is not dependent on the ETL process.

73. What is the datatype difference between a fact and dimension tables?
○ 1. Fact Tables
  • They hold numeric data.
  • They contain measures.
  • They are deep.
○ 2. Dimensional Tables
  • They hold textual data.
  • They contain attributes of their fact tables.
  • They are wide.
74. What are the types of dimension tables?
○ 1. Conformed Dimensions
■ when a particular dimension is connected to one or more fact tables. ex) time dimension
○ 2. Parent-child Dimensions
■ A parent-child dimension is distinguished by the fact that it contains a hierarchy based on a recursive relationship.
■ when a particular dimension points to its own surrogate key to show an unary relationship.
○ 3. Role Playing Dimensions
■ when a particular dimension plays different roles in the same fact table. ex) dim_time and orderDateKey, shippedDateKey...usually a time dimension table.
■ Role-playing dimensions conserve storage space, save processing time, and improve database manageability .
○ 4. Slowly Changing Dimensions: A dimension table that have data that changes slowly that occur by inserting and updating of records.
■ 1. Type 0: columns where changes are not allowed - no change ex) DOB, SSNm
■ 2. Type 1: columns where its values can be replaced without adding its new row - replacement
■ 3. Type 2: for any change for the value in a column, a new record it will be added - historical data. Previous values are saved in records marked as outdated. For even a single type 2 column, startDate, EndDate, and status are needed.
■ 4. Type 3: advanced version of type 2 where you can set up the upper limit of history which drops the oldest record when the limit has been reached with the help of outside SQL implementation.
■ Type 0 ~ 2 are implemented on the column level.
○ 5. Degenerated Dimensions: a particular dimension that has an one-to-one relationship between itself and the fact table.
■ When a particular Dimension table grows at the same rate as a fact table, the actual dimension can be removed and the dimensions from the dimension table can be inserted into the actual fact table.
■ You can see this mostly when the granularity level of the the facts are per transaction.
■ E.g. The dimension salesorderdate (or other dimensions in DimSalesOrder would grow everytime a sale is made therefore the dimension (attributes) would be moved into the fact table.
○ 6. Junk Dimensions: holds all miscellaneous attributes that may or may not necessarily belong to any other dimensions. It could be yes/no, flags, or long open-ended text data.

75. What is your strategy for the incremental load?
The combination of different techniques for the incremental load in my previous projects; time stamps, CDC (Change Data Capture), MERGE statement and CHECKSUM() in TSQL, LEFT OUTER JOIN, TRIGGER, the Lookup Transformation in SSIS.

76. What is CDC?
CDC (Change Data Capture) is a method to capture data changes, such as INSERT, UPDATE and DELETE, happening in a source table by reading transaction log files. Using CDC in the process of an incremental load, you are going to be able to store the changes in a SQL table, enabling us to apply the changes to a target table incrementally.

In data warehousing, CDC is used for propagating changes in the source system into your data warehouse, updating dimensions in a data mart, propagating standing data changes into your data warehouse and such.

The advantages of CDC are:
- It is almost real time ETL.
- It can handle small volume of data.
- It can be more efficient than replication.
- It can be auditable.
- It can be used to configurable clean up.
Disadvantages of CDC are:
- Lots of change tables and functions
- Bad for big changes e.g. truncate & reload
Optimization of CDC:
- Stop the capture job during load
- When applying changes to target, it is ideal to use merge.

77. What is the difference between a connection and session ?
○ Connection: It is the number of instance connected to the database. An instance is modelized soon as the application is open again. 
○ Session: A session run queries.In one connection, it allowed multiple sessions for one connection.

78.  What are all different types of collation sensitivity?
Following are different types of collation sensitivity -.

Case Sensitivity – A and a and B and b.
Accent Sensitivity.
Kana Sensitivity – Japanese Kana characters.
Width Sensitivity – Single byte character and double byte character.

79. What is CLAUSE?
SQL clause is defined to limit the result set by providing condition to the query. This usually filters some rows from the whole set of records.

Example – Query that has WHERE condition

Query that has HAVING condition.


80. What is Union, minus and Interact commands?
UNION operator is used to combine the results of two tables, and it eliminates duplicate rows from the tables.

MINUS operator is used to return rows from the first query but not from the second query. Matching records of first and second query and other rows from the first query will be displayed as a result set.

INTERSECT operator is used to return rows returned by both the queries.

81.How to fetch common records from two tables?
Common records result set can be achieved by -.

Select studentID from student. <strong>INTERSECT </strong> Select StudentID from Exam

82.How to fetch alternate records from a table?
Records can be fetched for both Odd and Even row numbers -.

To display even numbers-.

Select studentId from (Select rowno, studentId from student) where mod(rowno,2)=0
To display odd numbers-.

Select studentId from (Select rowno, studentId from student) where mod(rowno,2)=1
from (Select rowno, studentId from student) where mod(rowno,2)=1.[/sql]

83. How to select unique records from a table?
Select unique records from a table by using DISTINCT keyword.

Select DISTINCT StudentID, StudentName from Student.

84.How to remove duplicate rows from table?
  • Step 1: Selecting Duplicate rows from table
Select rollno FROM Student WHERE ROWID <>
(Select max (rowid) from Student b where rollno=b.rollno);
  • Step 2:  Delete duplicate rows
Delete FROM Student WHERE ROWID <>
(Select max (rowid) from Student b where rollno=b.rollno);


85.What is ROWID and ROWNUM in SQL?
RowID
1.ROWID is nothing but Physical memory allocation
2.ROWID is permanant to that row which identifies the address of that row.
3.ROWID is 16 digit Hexadecimal number which is uniquely identifies the rows.
4.ROWID returns PHYSICAL ADDRESS of that row.
5. ROWID is automatically generated unique id of a row and it is generated at the time of insertion of row.
6. ROWID is the fastest means of accessing data.

ROWNUM:
1. ROWNUM is nothing but the sequence which is allocated to that data retreival bunch.
2. ROWNUM is tempararily allocated sequence to the rows.
3.ROWNUM is numeric sequence number allocated to that row temporarily.
4.ROWNUM returns the sequence number to that row.
5. ROWNUM is an dynamic value automatically retrieved along with select statement output.
6.ROWNUM is not related to access of data.

86. How to find count of duplicate rows?
Select rollno, count (rollno) from Student
Group by rollno Having count (rollno)>1 Order by count (rollno) desc;

87.How to find Third highest salary in Employee table using self-join?
Select * from Employee a Where 3 = (Select Count (distinct Salary) from Employee where a.salary<=b.salary;

88. How to display following using query?
*

**

***
We cannot use dual table to display output given above. To display output use any table. I am using Student table.
SELECT lpad (‘*’, ROWNUM,’*’) FROM Student WHERE ROWNUM <4;

89. How to display Date in DD-MON-YYYY table?
Select to_date (Hire_date,’DD-MON-YYYY’) Date_Format from Employee;

90. If marks column contain the comma separated values from Student table. How to calculate the count of that comma separated values?
Student Name Marks
Dinesh 30,130,20,4
Kumar 100,20,30
Sonali 140,10

Select Student_name, regexp_count (marks,’,’) + As “Marks Count” from Student;

91. What is query to fetch last day of previous month in oracle?
Select LAST_DAY (ADD_MONTHS (SYSDATE,-1)) from dual;

92. How to display the String vertically in Oracle?
SELECT SUBSTR (‘AMIET’, LEVEL, 1) FROM dual
Connect by level <= length (‘AMIET’);

93. How to display departmentwise and monthwise maximum salary?
Select Department_no, TO_CHAR (Hire_date,’Mon’) as Month from Employee group by Department_no, TO_CHAR (Hire_date,’mon’);

94. How to calculate number of rows in table without using count function?
Select table_name, num_rows from user_tables where table_name=’Employee’;

Tip: User needs to use the system tables for the same. So using user_tables user will get the number of rows in the table

95. How to fetch common records from two different tables which has not any joining condition. ?

Select * from Table1
Intersect
Select * from Table2;

Tip: Use Intersect keyword for fetching common records.

96. Explain Execution Plan.?
  • Query optimizer is a part of SQL server that models the way in which the relational DB engine works and comes up with the most optimal way to execute a query. Query Optimizer takes into account amount of resources used, I/O and CPU processing time etc. to generate a plan that will allow query to execute in most efficient and faster manner. This is known as EXECUTION PLAN.
  • Optimizer evaluates a number of plans available before choosing the best and faster on available.
  • Every query has an execution plan.
  • Definition by the mod: Execution Plan is a plan to execute a query with the most optimal way which is generated by Query Optimizer. Query Optimizer analyzes statistics, resources used, I/O and CPU processing time and etc. and comes up with a number of plans. Then it evaluates those plans and the most optimized plan out of the plans is Execution Plan. It is shown to users as a graphical flow chart that should be read from right to left and top to bottom.


















Saturday, August 18, 2018

Sqoop Interview Question and Answers



Welcome to BigDatapedia


Presented By 
Dineshkumar Selvaraj

---------------------------------------------------------------------------

SQOOP Interview Questions with answer

1) What is SQOOP..?

This is the short meaning of (SQl+HadOOP =SQOOP)

It is a tool designed to transfer data between Hadoop and relational databases or mainframes. You can use Sqoop to import data from a relational database management system (RDBMS) such as MySQL or Oracle or a mainframe into the Hadoop Distributed File System (HDFS), transform the data in Hadoop MapReduce, and then export the data back into an RDBMS.

Sqoop automates most of this process, relying on the database to describe the schema for the data to be imported. Sqoop uses MapReduce to import and export the data, which provides parallel operation as well as fault tolerance.

The Sqoop main intended for:
  • System and application programmers
  • System administrators
  • Database administrators
  • Data analysts
  • Data engineers

2) Why is the default maximum mappers are 4 in Sqoop? 
As of my knowledge, the default number of mapper 4 is followed by minimum concurrent task for one machine. We will lead to set a higher number of concurrent tasks, which can result in faster job completion.

3) is it possible set speculative execution in Sqoop ..?
In sqoop by default speculative execution is off, because if Multiple mappers run for single task, we get duplicates of data in HDFS. Hence to avoid this decrepency it is off. Also number of reducers for sqoop job is 0, since it is merely a job running a MAP only job that dumps data into HDFS. We are not aggregating anything.

4) What causes of hadoop throw ClassNotFoundException while sqoop integration ..?
The most causes of that the supporting library (like connectors) was not updated in sqoop's library path, so we need to update it on that specific path.

5) How to view all the databases and tables in RDBMS from SQOOP..?
Using below commands we can,
  • sqoop-list-databases
  • sqoop-list-tables
6) How to view table columns details in RDBMS from SQOOP..?
Unfortunately we don't have any commands like sqoop-list-columns, But we can achieve via free form query to check the information schema for the particular RDBMS tables.

here is an example:
$ sqoop eval --connect 'jdbc:mysql://nameofmyserver;' database=nameofmydatabase; username=dineshkumar; password=dineshkumar --query "SELECT column_name, DATA_TYPE FROM INFORMATION_SCHEMA.Columns WHERE table_name='mytableofinterest' 

7)  I am getting FileAlreadyExists exception error in Sqoop while importing data from RDBMS to a hive table.? So How do we resolve it.?
you can specify the --hive-overwrite option to indicate that existing table in hive must be replaced. After your data is imported into HDFS or this step is omitted

8) What is the default file format to import data using Apache Sqoop? 
Sqoop allows data to be imported using two file formats

i) Delimited Text File Format
This is the default file format to import data using Sqoop. This file format can be explicitly specified using the –as-textfile argument to the import command in Sqoop. Passing this as an argument to the command will produce the string based representation of all the records to the output files with the delimited characters between rows and columns.

ii) Sequence File Format
It is a binary file format where records are stored in custom record-specific data types which are shown as Java classes. Sqoop automatically creates these data types and manifests them as java classes.

9) How do I resolve a Communications Link Failure when connecting to MySQL? 
Verify that you can connect to the database from the node where you are running Sqoop:
$ mysql --host=IP Address --database=test --user=username --password=password
Add the network port for the server to your my.cnf file
Set up a user account to connect via Sqoop. Grant permissions to the user to access the database over the network:
Log into MySQL as root mysql -u root -p ThisIsMyPassword
Issue the following command: mysql> grant all privileges on test.* to 'testuser'@'%' identified by 'testpassword'

10) How do I resolve an IllegalArgumentException when connecting to Oracle? 
This could be caused a non-owner trying to connect to the table so prefix the table name with the schema, for example SchemaName.OracleTableName. 

11) What's causing this Exception in thread main java.lang.IncompatibleClassChangeError when running non-CDH Hadoop with Sqoop? 

Try building Sqoop 1.4.1-incubating with the command line property -Dhadoopversion=20. 

12) I have around 300 tables in a database. I want to import all the tables from the database except the tables named Table298, Table 123, and Table299. How can I do this without having to import the tables one by one? 
This can be accomplished using the import-all-tables import command in Sqoop and by specifying the exclude-tables option with it as follows-
sqoop import-all-tables
--connect –username –password --exclude-tables Table298, Table 123, Table 299 

13) Does Apache Sqoop have a default database? 

Yes, MySQL is the default database. 

14) How can I import large objects (BLOB and CLOB objects) in Apache Sqoop? 
Apache Sqoop import command does not support direct import of BLOB and CLOB large objects. To import large objects, I Sqoop, JDBC based imports have to be used without the direct argument to the import utility. 

15) How can you execute a free form SQL query in Sqoop to import the rows in a sequential manner? 
This can be accomplished using the –m 1 option in the Sqoop import command. It will create only one MapReduce task which will then import rows serially. 

16) What is the difference between Sqoop and DistCP command in Hadoop? 
Both distCP (Distributed Copy in Hadoop) and Sqoop transfer data in parallel but the only difference is that distCP command can transfer any kind of data from one Hadoop cluster to another whereas Sqoop transfers data between RDBMS and other components in the Hadoop ecosystem like HBase, Hive, HDFS, etc. 

17) What is Sqoop metastore? 
Sqoop metastore is a shared metadata repository for remote users to define and execute saved jobs created using sqoop job defined in the metastore. The sqoop –site.xml should be configured to connect to the metastore. 

18) What is the significance of using –split-by clause for running parallel import tasks in Apache Sqoop? 
--Split-by clause is used to specify the columns of the table that are used to generate splits for data imports. This clause specifies the columns that will be used for splitting when importing the data into the Hadoop cluster. —split-by clause helps achieve improved performance through greater parallelism. Apache Sqoop will create splits based on the values present in the columns specified in the –split-by clause of the import command. If the –split-by clause is not specified, then the primary key of the table is used to create the splits while data import. At times the primary key of the table might not have evenly distributed values between the minimum and maximum range. Under such circumstances –split-by clause can be used to specify some other column that has even distribution of data to create splits so that data import is efficient. 

19) You use –split-by clause but it still does not give optimal performance then how will you improve the performance further. 
Using the –boundary-query clause. Generally, sqoop uses the SQL query select min (), max () from to find out the boundary values for creating splits. However, if this query is not optimal then using the –boundary-query argument any random query can be written to generate two numeric columns. 

20) During sqoop import, you use the clause –m or –numb-mappers to specify the number of mappers as 8 so that it can run eight parallel MapReduce tasks, however, sqoop runs only four parallel MapReduce tasks. Why? 
Hadoop MapReduce cluster is configured to run a maximum of 4 parallel MapReduce tasks and the sqoop import can be configured with number of parallel tasks less than or equal to 4 but not more than 4. 

21) You successfully imported a table using Apache Sqoop to HBase but when you query the table it is found that the number of rows is less than expected. What could be the likely reason? 
If the imported records have rows that contain null values for all the columns, then probably those records might have been dropped off during import because HBase does not allow null values in all the columns of a record. 

22) The incoming value from HDFS for a particular column is NULL. How will you load that row into RDBMS in which the columns are defined as NOT NULL? 
Using the –input-null-string parameter, a default value can be specified so that the row gets inserted with the default value for the column that it has a NULL value in HDFS. 

23) How will you synchronize the data in HDFS that is imported by Sqoop? 
Data can be synchronised using incremental parameter with data import –
--Incremental parameter can be used with one of the two options-
i) append-If the table is getting updated continuously with new rows and increasing row id values then incremental import with append option should be used where values of some of the columns are checked (columns to be checked are specified using –check-column) and if it discovers any modified value for those columns then only a new row will be inserted.
ii) lastmodified – In this kind of incremental import, the source has a date column which is checked for. Any records that have been updated after the last import based on the lastmodifed column in the source, the values would be updated.

24) What are the relational databases supported in Sqoop? 
Below are the list of RDBMSs that are supported by Sqoop Currently.
MySQL
PostGreSQL
Oracle
Microsoft SQL
IBM’s Netezza
Teradata

25) What are the destination types allowed in Sqoop Import command? 
Currently Sqoop Supports data imported into below services.
HDFS
Hive
HBase
HCatalog
Accumulo 

26)  Is Sqoop similar to distcp in hadoop? 
Partially yes, hadoop’s distcp command is similar to Sqoop Import command. Both submits parallel map-only jobs.
But distcp is used to copy any type of files from Local FS/HDFS to HDFS and Sqoop is for transferring the data records only between RDMBS and Hadoop eco system services, HDFS, Hive and HBase. 

27)What are the majorly used commands in Sqoop? 
In Sqoop Majorly Import and export commands are used. But below commands are also useful some times.
codegen
eval
import-all-tables
job
list-databases
list-tables
merge
metastore 

28) While loading tables from MySQL into HDFS, if we need to copy tables with maximum possible speed, what can you do ? 
We need to use –direct argument in import command to use direct import fast path and this –direct can be used only with MySQL and PostGreSQL as of now. 

29) While connecting to MySQL through Sqoop, I am getting Connection Failure exception what might be the root cause and fix for this error scenario? 
This might be due to insufficient permissions to access your MySQL database over the network. To confirm this we can try the below command to connect to MySQL database from Sqoop’s client machine. 

$ mysql --host=MySql node > --database=test --user= --password= 
If this is the case then we need grant permissions user @ sqoop client machine as per the answer to Question 6 in this post.

30) What is the importance of eval tool? 
It allow users to run sample SQL queries against Database and preview the result on the console. 

31) What is the process to perform an incremental data load in Sqoop? 
The process to perform incremental data load in Sqoop is to synchronize the modified or updated data (often referred as delta data) from RDBMS to Hadoop. The delta data can be facilitated through the incremental load command in Sqoop.

Incremental load can be performed by using Sqoop import command or by loading the data into hive without overwriting it. The different attributes that need to be specified during incremental load in Sqoop are-
1)Mode (incremental) –The mode defines how Sqoop will determine what the new rows are. The mode can have value as Append or Last Modified.
2)Col (Check-column) –This attribute specifies the column that should be examined to find out the rows to be imported.
3)Value (last-value) –This denotes the maximum value of the check column from the previous import operation.

32) What is the significance of using –compress-codec parameter? 
To get the out file of a sqoop import in formats other than .gz like .bz2 compressions when we use the –compress -code parameter. 

33) Can free form SQL queries be used with Sqoop import command? If yes, then how can they be used? 
Sqoop allows us to use free form SQL queries with the import command. The import command should be used with the –e and – query options to execute free form SQL queries. When using the –e and –query options with the import command the –target dir value must be specified. 

34) What is the purpose of sqoop-merge? 
The merge tool combines two datasets where entries in one dataset should overwrite entries of an older dataset preserving only the newest version of the records between both the data sets. 

35) How do you clear the data in a staging table before loading it by Sqoop? 
By specifying the –clear-staging-table option we can clear the staging table before it is loaded. This can be done again and again till we get proper data in staging. 

36) How will you update the rows that are already exported? 
The parameter –update-key can be used to update existing rows. In a comma-separated list of columns is used which uniquely identifies a row. All of these columns is used in the WHERE clause of the generated UPDATE query. All other table columns will be used in the SET part of the query. 

37) What is the role of JDBC driver in a Sqoop set up? 
To connect to different relational databases sqoop needs a connector. Almost every DB vendor makes this connecter available as a JDBC driver which is specific to that DB. So Sqoop needs the JDBC driver of each of the database it needs to interact with. 

38) When to use --target-dir and --warehouse-dir while importing data? 
To specify a particular directory in HDFS use --target-dir but to specify the parent directory of all the sqoop jobs use --warehouse-dir. In this case under the parent directory sqoop will create a directory with the same name as the table. 

39) When the source data keeps getting updated frequently, what is the approach to keep it in sync with the data in HDFS imported by sqoop? 
sqoop can have 2 approaches.

  • To use the --incremental parameter with append option where value of some columns are checked and only in case of modified values the row is imported as a new row.
  • To use the --incremental parameter with lastmodified option where a date column in the source is checked for records which have been updated after the last import.
40) Is it possible to add a parameter while running a saved job? 
Yes, we can add an argument to a saved job at runtime by using the --exec option
sqoop job --exec jobname -- -- newparameter

41) sqoop takes a long time to retrieve the minimum and maximum values of columns mentioned in –split-by parameter. How can we make it efficient? 
We can use the --boundary –query parameter in which we specify the min and max value for the column based on which the split can happen into multiple mapreduce tasks. This makes it faster as the query inside the –boundary-query parameter is executed first and the job is ready with the information on how many mapreduce tasks to create before executing the main query. 

42) How will you implement all-or-nothing load using sqoop ? 
Using the staging-table option we first load the data into a staging table and then load it to the final target table only if the staging load is successful. 

43) How will you update the rows that are already exported ?
The parameter --update-key can be used to update existing rows. In it a comma-separated list of columns is used which uniquely identifies a row. All of these columns is used in the WHERE clause of the generated UPDATE query. All other table columns will be used in the SET part of the query. 

44) How can you sync a exported table with HDFS data in which some rows are deleted.? 
Truncate the target table and load it again. 

45) How can we load to a column in a relational table which is not null but the incoming value from HDFS has a null value.? 
By using the –input-null-string parameter we can specify a default value and that will allow the row to be inserted into the target table. 

46) How can you schedule a sqoop job using Oozie? 
Oozie has in-built sqoop actions inside which we can mention the sqoop commands to be executed. 

47) Sqoop imported a table successfully to HBase but it is found that the number of rows is fewer than expected. What can be the cause? 
Some of the imported records might have null values in all the columns. As Hbase does not allow all null values in a row, those rows get dropped. 

48) How can you force sqoop to execute a free form Sql query only once and import the rows serially. ?
By using the –m 1 clause in the import command, sqoop creates only one mapreduce task which will import the rows sequentially. 

49) In a sqoop import command you have mentioned to run 8 parallel Mapreduce task but sqoop runs only 4. What can be the reason? 
The Mapreduce cluster is configured to run 4 parallel tasks. So the sqoop command must have number of parallel tasks less or equal to that of the MapReduce cluster. 

50) What happens when a table is imported into a HDFS directory which already exists using the –append parameter? 
Using the --append argument, Sqoop will import data to a temporary directory and then rename the files into the normal target directory in a manner that does not conflict with existing filenames in that directory. 

51) How to import only the updated rows form a table into HDFS using sqoop assuming the source has last update timestamp details for each row? 
By using the lastmodified mode. Rows where the check column holds a timestamp more recent than the timestamp specified with --last-value are imported. 

52) Give a Sqoop command to import all the records from employee table divided into groups of records by the values in the column department_id. 
$ sqoop import --connect jdbc:mysql://DineshDB --table EMPLOYEES  --split-by dept_id -m2

53) What does the following query do? 
$ sqoop import --connect jdbc:mysql://DineshDB --table sometable --where "id > 1000" --target-dir "/home/dinesh/sqoopincremental" --append 
It performs an incremental import of new data, after having already imported the first 1000 rows of a table 

54) What is the importance of $CONDITIONS in Sqoop..?
Sqoop performs highly efficient data transfers by inheriting Hadoop’s parallelism.

  • To help Sqoop split your query into multiple chunks that can be transferred in parallel, you need to include the $CONDITIONS placeholder in the where clause of your query.
  • Sqoop will automatically substitute this placeholder with the generated conditions specifying which slice of data should be transferred by each individual task.
  • While you could skip $CONDITIONS by forcing Sqoop to run only one job using the --num-mappers 1 param‐ eter, such a limitation would have a severe performance impact.

For example:-
If you run a parallel import, the map tasks will execute your query with different values substituted in for $CONDITIONS. one mapper may execute "select * from TblDinesh WHERE (salary>=0 AND salary < 10000)", and the next mapper may execute "select * from TblDinesh WHERE (salary >= 10000 AND salary < 20000)" and so on.

55) can sqoop run without a hadoop cluster.?
To run Sqoop commands, Hadoop is a mandatory prerequisite. You cannot run sqoop commands without the Hadoop libraries.

56) Is it possible to import a file in fixed column length from the database using sqoop import? 
Importing column of a fixed length from any database you can use free form query like below

sqoop import --connect jdbc:oracle:* --username Dinesh --password pwd 
-e "select substr(COL1,1,4000),substr(COL2,1,4000) from table where \$CONDITIONS" 
--target-dir /user/dineshkumar/table_name --as-textfile -m 1

57) How to use sqoop validation?
You can use this parameter (--validate) to validate the counts between what’s imported/exported between RDBMS and HDFS.

58) How to pass sqoop command as file arguments in Sqoop.?
specify an options file, simply create an options file in a convenient location and pass it to the command line via --options-file argument.
eg: sqoop --options-file /users/homer/work/import.txt --table TEST

59) is it possible to import data apart from HDFS and Hive.?
Sqoop supports additional import targets beyond HDFS and Hive. Sqoop can also import records into a table in HBase and Accumulo.

60) is it possible to use sqoop --direct command in Hbase .?
This function is incompatible with direct import. But Sqoop can do bulk loading as opposed to direct writes. To use bulk loading, enable it using --hbase-bulkload.

61) Can I configure two sqoop command so that they are dependent on each other? Like if the first sqoop job is successful, second gets triggered. If first fails, second should not run..?
No, using sqoop commands it is not possible, but You can use oozie for this. Create an oozie workflow. Execute the second action only if the first action succeeds.

62) What is UBER mode and where is the settings to enable in Hadoop .?
Normally mappers and reducers will run by ResourceManager (RM), RM will create separate container for mapper and reducer. Uber configuration, will allow to run mapper and reducers in the same process as the ApplicationMaster (AM).

Uber jobs :
Uber jobs are jobs that are executed within the MapReduce ApplicationMaster. Rather then communicate with RM to create the mapper and reducer containers. The AM runs the map and reduce tasks within its own process and avoided the overhead of launching and communicate with remote containers.

Why :
If you have a small dataset or you want to run MapReduce on small amount of data, Uber configuration will help you out, by reducing additional time that MapReduce normally spends in mapper and reducers phase.

Can I configure an Uber for all MapReduce job?
As of now, map-only jobs and jobs with one reducer are supported.

Settings:
Uber Job occurs when multiple mapper and reducers are combined to use a single container. There are four core settings around the configuration of Uber Jobs in the mapred-site.xml. Configuration options for Uber Jobs:
mapreduce.job.ubertask.enable
mapreduce.job.ubertask.maxmaps
mapreduce.job.ubertask.maxreduces
mapreduce.job.ubertask.maxbytes

...All The Best...