Nested Queries (Sub Queries) A nested query is a form of a SELECT command that appears inside another SQL statement. It is also termed as subquery. The SELECT command containing a subquery are referred as parent statement. The row returned by the subquery are used by the parent statement. Use of Nested Query: Develop complex commands (query) Define the sets of rows to be inserted into the target table of INSERT or CREATE table command or CREATE VIEW Ex :for INSERT Insertion with subquery SQL> INSERT INTO S_EMP SELECT * FROM EMP WHERE dept = ‘Sales’ Ex : for CREATE table (To remove particular column, delete sex field from emp table)
1.SQL> CREATE table t_emp as ( SELECT eno,ename,dept,post,basic from emp); 2.SQL> DROP table emp; 3.SQL> RENAME t_emp to emp; To define one or more values to be assigned to existing rows in an UPDATE command. To provide values for conditions in WHERE, HAVING clauses of SELECT, UPDATE and DELETE command.
EnoEnameDeptpostbasic 111KumarSalesManager UmarPurchaseAccountant VinoSalesClerk RajMarketingManager MuniyaPurchaseManager OmnaSalesAsst.Manager12000
Using Sub query in SELECT command Ex:1 To find all employees who have the same post as Raj. ordinary way step 1: SQL> select post from emp where ename = ‘Raj’; output - Manager step 2: SQL> select * from emp where post = ‘Manager; output -111 kumar Sales Manager raj Marketing Manager Sub query way SQL> select * from emp where post = ( select post from emp where ename = ‘Raj’);
Subquery returning more than one column: Ex: To find all employees who have same post and basic as ‘Raj’ SQL> select * from emp where (post,basic) = (select post,basic from emp where ename = ‘Raj’; output: 444 Raj Marketing Manager Muniya PurchaseManager15000 Subquery returning more than one row: (Ex : ANY operator) Ex: To find all employees who earn more than any employee in Purchase department SQL> select * from emp where basic > ANY (select basic from emp where dept = ‘Purchase’; output:
(Ex : ALL operator) Ex: To find all employees who earn more than all employee in Purchase department SQL>select * from emp where basic > ALL (select basic from emp where dept = ‘Purchase’; output: Multiple Subqueries: The WHERE clause of a query may contain any combination of ordinary conditions and subqueries with the help of AND or OR operator. Ex : To list all employees with either the same department as ‘Kumar’ or a basic grater than or equal to ‘Raj’ select * from emp where dept = (select dept from emp where ename = ‘Kumar’) or basic >= (select basic from emp where ename = ‘RAj’); Outout:
Correlated Subquery: In the ordinary subquery ( previous examples), each subquery was executed once and the resulting value was used by the WHERE clause of the main query. We can also frame a subquery that can be executed repeatedly once for each candidate in each through the main query, Which is called correlated subquery. Ex: To find employees who earn more then the average salary in their own department. SQL> select * from emp X where basic > (select avg(sal) from emp where X.dept = dept); Output: 111 Kumar Sales Manager Muniya Purchase Manager Omna Sales Asst.Manager 12000
Joining Data from multiple tables Rows in one table may be joined to rows in another by common value in corresponding columns. The ability of the relational ‘join’ operator is an important feature of relational systems. A join makes it possible to select data from more than one table by means of a single statement. The joining of table is done in SQL by specifying the table to be joined in the FROM clause of the SELECT command using WHERE conditions. Basic Syntax: SELECT columns FROM table1, table2, …… WHERE ;
Ex: Consider two tables such as EMP and SALARY EnoEnameDeptpost 111KumarSalesManager 222UmarPurchaseAccountant 333VinoSalesClerk 444RajMarketingManager 555MuniyaPurchaseManager 666OmnaSalesAsst.Manager 888JeevaMarketingClerk
SALARY EnoBasicDAHRAMAPF
Ex: To list all employee’s personal and salary details from the table EMP and SALARY. SQL> SELECT x.eno,x.ename,x.dept,x.post,y.basic,y.da,y.hra,y.ma,y.pf FROM emp x, salary y WHERE x.eno = y.eno; OR SQL> SELECT emp.eno,emp.ename,emp.dept,emp.post,salary.basic, salary.da,salary.hra,salary.ma,salary.pf FROM emp, salary WHERE emp.eno = salary.eno; ENO ENAME DEPT POST BASIC DA HRA MA PF Kumar Sales Manager Umar Purchase Account Vino Sales Clerk Raj Marketing Manager Muniya Purchase Manager Omna Sales As.manager
Types of Join Three types, such as 1.Equijoin 2.Non-equijoin 3.Outer join Equijoin When we join two or more tables using the relational operator = (equal) in the join condition, then it is Equijoin. In joining tables, a join condition that specifies a relationship = ( equal) is called Equijoin. Ex: Above example, The type of join in the above example is termed as equijoin because the comparison operator in the join condition is = (equal) SQL> SELECT x.eno,x.ename,x.dept,x.post,y.basic,y.da,y.hra,y.ma,y.pf FROM emp x, salary y WHERE x.eno = y.eno;
Non – Equijoin When we join two or more tables using the relational operator except = (equal) in the join condition, then it is Non -Equijoin. In joining tables, a join condition that specifies a relationship other than = ( equal) is called Non - Equijoin. Ex: To find the salaries and jobs of employees who earn more than employee no 666 (Omna) SQL> SELECT x.eno,x.basic,x.da,x.hra,x.ma,x.pf FROM salary x, salary y WHERE x.basic > y.basic AND y.eno = 666; ENO BASIC DA HRA MA PF
Self – Join Note that in the above example, the same table has been joined to achieve the required result such type of join statement involving the joining of the same table is termed as self-join. Outer – Join Suppose one or more rows in one of the table does not satisfy the join condition, that rows ordinarily will not appear in the query’s result. If we still wish to display those rows (not satisfied rows), then use Outer-Join operator. ie (+) a plus enclosed in parenthesis
Ex:To list all employee’s personal and salary details from the table EMP and SALARY SQL> SELECT x.eno,x.ename,x.dept,x.post,y.basic,y.da,y.hra,y.ma,y.pf FROM emp x, salary y WHERE x.eno = y.eno(+); ENO ENAME DEPT POST BASIC DA HRA MA PF Kumar Sales Manager Umar Purchase Account Vino Sales Clerk Raj Marketing Manager Muniya Purchase Manager Omna Sales As.manager Jeeva Marketing Clerk
SQL> SELECT x.eno,x.ename,x.dept,x.post,y.basic,y.da,y.hra,y.ma,y.pf FROM emp x, salary y WHERE x.eno(+) = y.eno; ENO ENAME DEPT POST BASIC DA HRA MA PF Kumar Sales Manager Umar Purchase Account Vino Sales Clerk Raj Marketing Manager Muniya Purchase Manager Omna Sales As.manager