SQL QUERIES-8
Display Data from Multiple Tables:JOINS
Group by
• The SQL GROUP BY clause is used in collaboration
with the SELECT statement to arrange identical data
into groups. This GROUP BY clause follows the
WHERE clause in a SELECT statement
• Syntax
• SELECT column1, column2 FROM table_name
WHERE [ conditions ] GROUP BY column1, column2
• SELECT NAME, SUM(SALARY) FROM CUSTOMERS
GROUP BY NAME;
Having clause
• The WHERE clause places conditions on the
selected columns, whereas the HAVING clause
places conditions on groups created by the GROUP
BY clause.
• SELECT column1, column2 FROM table1, table2
WHERE [ conditions ] GROUP BY column1, column2
HAVING [ conditions ]
• SELECT id,SUM(salary) FROM employee GROUP BY
id having id>2;
JOINS
• SQL Join is used to fetch data from two or more
tables, which is joined to appear as single set of
data.
• SQL Join is used for combining column from two or
more tables by using values common to both
tables.
• Join Keyword is used in SQL queries for joining two
or more tables. Minimum required condition for
joining table, is(n-1) where n, is number of tables.
• A table can also join to itself known as, Self Join.
• Following the types:
1.Cross JOIN or Cartesian Product
• This type of JOIN returns the cartesian product of
rows from the tables in Join.
• It will return a table which consists of records
which combines each row from the first table with
each row of the second table.
• Cross JOIN Syntax is:
• SELECT column-name-list from table-name1 CROSS
JOIN table-name2;
• SELECT * from class cross JOIN class_info;
Example of Cross JOIN
The Class table The class_info table
ID NAME ID Address
1 abhi 1 DELHI
2 adam 2 MUMBAI
4 alex 3 CHENNAI
• Cross JOIN query will be,
• SELECT * from class cross JOIN class_info;
• The resultant table is:
ID NAME ID Address
1 abhi 1 DELHI
2 adam 1 DELHI
4 alex 1 DELHI
1 abhi 2 MUMBAI
2 adam 2 MUMBAI
4 alex 2 MUMBAI
1 abhi 3 CHENNAI
2 adam 3 CHENNAI
4 alex 3 CHENNAI
2.INNER Join or EQUI Join
• This is a simple JOIN in which the result is based on
matched data as per the equality condition
specified in the query.
• Inner Join Syntax is,
• SELECT column-name-list from table-name1 INNER
JOIN table-name2 WHERE table-name1.column-
name = table-name2.column-name;
• SELECT * from class, class_info where class.id =
class_info.id;
• The result table will look like,
ID NAME ID Address
1 abhi 1 DELHI
2 adam 2 MUMBAI
3 alex 3 CHENNAI
3.NATURAL JOIN
• Natural Join is a type of Inner join which is based on
column having same name and same datatype
present in both the tables to be joined.
• Natural Join Syntax is,
• SELECT * from table-name1 NATURAL JOIN table-
name2;
• SELECT * from class NATURAL JOIN class_info;
Example of Natural JOIN
The class table, The class_info table,
ID NAME ID Address
1 abhi
1 DELHI
2 adam
2 MUMBAI
3 alex
3 CHENNAI
4 anu
• Natural join query will be,
• SELECT * from class NATURAL JOIN class_info; The
result table will look like,
ID NAME Address
1 abhi DELHI
2 adam MUMBAI
3 alex CHENNAI
• In the above example, both the tables being joined
have ID column(same name and same datatype),
hence the records for which value of ID matches in
both the tables will be the result of Natural Join of
these two tables.
4.Outer JOIN
• Outer Join is based on both matched and
unmatched data. Outer Joins subdivide further into,
• Left Outer Join
• Right Outer Join
• Full Outer Join
Left Outer Join
• The left outer join returns a result table with
the matched data of two tables then remaining
rows of the left table and null for the right table's
column.
• Left outer Join Syntax for Oracle is,
• select column-name-list from table-name1 LEFT
OUTER JOIN on table-name1.column-name =
table-name2.column-name.
• SELECT * FROM class LEFT OUTER JOIN class_info
ON (class.id=class_info.id);
Right Outer Join
• The right outer join returns a result table with
the matched data of two tables then remaining
rows of the right table and null for the left table's
columns.
• Right outer Join Syntax for Oracle is,
• select column-name-list from table-name1, table-
name2 on table-name1.column-name= table-
name2.column-name;
• SELECT * FROM class RIGHT OUTER JOIN class_info
ON (class.id=class_info.id);
Full Outer Join
• The full outer join returns a result table with
the matched data of two table then remaining rows
of both lefttable and then the right table.
• Full Outer Join Syntax is,
• select column-name-list from table-name1 FULL
OUTER JOIN table-name2 on table-name1.column-
name = table-name2.column-name;
• SELECT * FROM class FULL OUTER JOIN class_info
ON (class.id=class_info.id);
• The SQL SELF JOIN is used to join a table to itself as
if the table were two tables.
• SELECT a.column_name, b.column_name FROM
table1 a, table1 b WHERE a.common_field =
b.common_field;
• SELECT a.ID, b.NAME, a.SALARY FROM CUSTOMERS
a, CUSTOMERS b WHERE a.SALARY < b.SALARY;