Displaying Data from Multiple Tables

25
4 Copyright © Oracle Corporation, 2001. All rights reserved. Displaying Data from Multiple Tables

description

Displaying Data from Multiple Tables. Objectives. After completing this lesson, you should be able to do the following: Write SELECT statements to access data from more than one table using equality and nonequality joins - PowerPoint PPT Presentation

Transcript of Displaying Data from Multiple Tables

Page 1: Displaying Data  from Multiple Tables

4Copyright © Oracle Corporation, 2001. All rights reserved.

Displaying Data from Multiple Tables

Page 2: Displaying Data  from Multiple Tables

4-2 Copyright © Oracle Corporation, 2001. All rights reserved.

Objectives

After completing this lesson, you should be able to do the following:

• Write SELECT statements to access data from more than one table using equality and nonequality joins

• View data that generally does not meet a join condition by using outer joins

• Join a table to itself by using a self join

Page 3: Displaying Data  from Multiple Tables

4-3 Copyright © Oracle Corporation, 2001. All rights reserved.

Obtaining Data from Multiple TablesEMPLOYEES DEPARTMENTS

Page 4: Displaying Data  from Multiple Tables

4-4 Copyright © Oracle Corporation, 2001. All rights reserved.

Cartesian Products

• A Cartesian product is formed when:

– A join condition is omitted

– A join condition is invalid

– All rows in the first table are joined to all rows in the second table

• To avoid a Cartesian product, always include a valid join condition in a WHERE clause.

Page 5: Displaying Data  from Multiple Tables

4-5 Copyright © Oracle Corporation, 2001. All rights reserved.

Generating a Cartesian Product

Cartesianproduct:

20x8=160 rows

EMPLOYEES (20 rows) DEPARTMENTS (8 rows)

Page 6: Displaying Data  from Multiple Tables

4-6 Copyright © Oracle Corporation, 2001. All rights reserved.

• Equijoin

• Non-equijoin

• Outer join

• Self join

Types of Joins

• Cross joins

• Full or two sided outer joins

• Arbitrary join conditions for outer joins

SQL: 1999 Compliant Joins:SQL: 1999 Compliant Joins:

Oracle Proprietary Joins (8i and prior): Oracle Proprietary Joins (8i and prior):

Page 7: Displaying Data  from Multiple Tables

4-7 Copyright © Oracle Corporation, 2001. All rights reserved.

Joining Tables Using Oracle Syntax

Use a join to query data from more than one table.

• Write the join condition in the WHERE clause.

• Prefix the column name with the table name when the same column name appears in more than one table.

SELECT table1.column, table2.columnFROM table1, table2WHERE table1.column1 = table2.column2;

SELECT table1.column, table2.columnFROM table1, table2WHERE table1.column1 = table2.column2;

Page 8: Displaying Data  from Multiple Tables

4-8 Copyright © Oracle Corporation, 2001. All rights reserved.

What is an Equijoin?

EMPLOYEES DEPARTMENTS

Foreign key Primary key

… …

Page 9: Displaying Data  from Multiple Tables

4-9 Copyright © Oracle Corporation, 2001. All rights reserved.

SELECT employees.employee_id, employees.last_name, employees.department_id, departments.department_id, departments.location_idFROM employees, departmentsWHERE employees.department_id = departments.department_id;

Retrieving Records with Equijoins

Page 10: Displaying Data  from Multiple Tables

4-10 Copyright © Oracle Corporation, 2001. All rights reserved.

Qualifying Ambiguous Column Names

• Use table prefixes to qualify column names that are in multiple tables.

• Improve performance by using table prefixes.

• Distinguish columns that have identical names but reside in different tables by using column aliases.

Page 11: Displaying Data  from Multiple Tables

4-11 Copyright © Oracle Corporation, 2001. All rights reserved.

SELECT e.employee_id, e.last_name, e.department_id,

d.department_id, d.location_id

FROM employees e , departments d

WHERE e.department_id = d.department_id;

Using Table Aliases

• Simplify queries by using table aliases.

• Improve performance by using table prefixes.

Page 12: Displaying Data  from Multiple Tables

4-12 Copyright © Oracle Corporation, 2001. All rights reserved.

Joining More than Two Tables

EMPLOYEES LOCATIONS DEPARTMENTS

• To join n tables together, you need a minimum of n-1 join conditions. For example, to join three tables, a minimum of two joins is required.

Page 13: Displaying Data  from Multiple Tables

4-13 Copyright © Oracle Corporation, 2001. All rights reserved.

Non-Equijoins

EMPLOYEES JOB_GRADES

Salary in the EMPLOYEES table must be between lowest salary and highest salary in the JOB_GRADEStable.

Page 14: Displaying Data  from Multiple Tables

4-14 Copyright © Oracle Corporation, 2001. All rights reserved.

Retrieving Records with Non-Equijoins

SELECT e.last_name, e.salary, j.grade_levelFROM employees e, job_grades jWHERE e.salary BETWEEN j.lowest_sal AND j.highest_sal;

Page 15: Displaying Data  from Multiple Tables

4-15 Copyright © Oracle Corporation, 2001. All rights reserved.

Outer Joins

EMPLOYEESDEPARTMENTS

There are no employees in department 190.

Page 16: Displaying Data  from Multiple Tables

4-16 Copyright © Oracle Corporation, 2001. All rights reserved.

Outer Joins Syntax

• You use an outer join to also see rows that do not meet the join condition.

• The Outer join operator is the plus sign (+).

SELECT table1.column, table2.column

FROM table1, table2

WHERE table1.column(+) = table2.column;

SELECT table1.column, table2.column

FROM table1, table2

WHERE table1.column(+) = table2.column;

SELECT table1.column, table2.column

FROM table1, table2

WHERE table1.column = table2.column(+);

SELECT table1.column, table2.column

FROM table1, table2

WHERE table1.column = table2.column(+);

Page 17: Displaying Data  from Multiple Tables

4-17 Copyright © Oracle Corporation, 2001. All rights reserved.

SELECT e.last_name, e.department_id, d.department_name

FROM employees e, departments d

WHERE e.department_id(+) = d.department_id ;

Using Outer Joins

Page 18: Displaying Data  from Multiple Tables

4-18 Copyright © Oracle Corporation, 2001. All rights reserved.

Self Joins

EMPLOYEES (WORKER) EMPLOYEES (MANAGER)

MANAGER_ID in the WORKER table is equal to EMPLOYEE_ID in the MANAGER table.

… …

Page 19: Displaying Data  from Multiple Tables

4-19 Copyright © Oracle Corporation, 2001. All rights reserved.

Joining a Table to Itself

SELECT worker.last_name || ' works for '

|| manager.last_name

FROM employees worker, employees manager

WHERE worker.manager_id = manager.employee_id ;

Page 20: Displaying Data  from Multiple Tables

4-20 Copyright © Oracle Corporation, 2001. All rights reserved.

Creating Cross Joins

• The CROSS JOIN clause produces the cross-product of two tables.

• This is the same as a Cartesian product between the two tables.

SELECT last_name, department_nameFROM employeesCROSS JOIN departments ;

Page 21: Displaying Data  from Multiple Tables

4-21 Copyright © Oracle Corporation, 2001. All rights reserved.

INNER Versus OUTER Joins

• In SQL: 1999, the join of two tables returning only matched rows is an inner join.

• A join between two tables that returns the results of the inner join as well as unmatched rows left (or right) tables is a left (or right) outer join.

• A join between two tables that returns the results of an inner join as well as the results of a left and right join is a full outer join.

Page 22: Displaying Data  from Multiple Tables

4-22 Copyright © Oracle Corporation, 2001. All rights reserved.

SELECT e.last_name, e.department_id, d.department_nameFROM employees eLEFT OUTER JOIN departments dON (e.department_id = d.department_id) ;

LEFT OUTER JOIN

Page 23: Displaying Data  from Multiple Tables

4-23 Copyright © Oracle Corporation, 2001. All rights reserved.

SELECT e.last_name, e.department_id, d.department_nameFROM employees eRIGHT OUTER JOIN departments dON (e.department_id = d.department_id) ;

RIGHT OUTER JOIN

Page 24: Displaying Data  from Multiple Tables

4-24 Copyright © Oracle Corporation, 2001. All rights reserved.

SELECT e.last_name, e.department_id, d.department_nameFROM employees eFULL OUTER JOIN departments dON (e.department_id = d.department_id) ;

FULL OUTER JOIN

Page 25: Displaying Data  from Multiple Tables

4-25 Copyright © Oracle Corporation, 2001. All rights reserved.

SELECT e.employee_id, e.last_name, e.department_id, d.department_id, d.location_idFROM employees e JOIN departments dON (e.department_id = d.department_id)AND e.manager_id = 149 ;

Additional Conditions