SELF JOIN
A self join is a special type of inner join where a table is joined to itself.
They are useful when you want to find records that have values in common with other rows in the same table.
This means that the table must appear twice and therefore you must use table alias names.
In order to join a table to itself you use table aliases.
These table aliases must be used throughout the query to represent the two tables.
SELECT C1.CompanyName
FROM [CUSTOMERS] C1
INNER JOIN [CUSTOMERS] C2
ON C1.CustomerID = C2.CustomerID
Alternative
SELECT C1.CompanyName
FROM [CUSTOMERS] C1
,[CUSTOMERS] C2
WHERE C1.CustomerID = C2.CustomerID
This is a special type of inner join where a table is joined to itself.
This means that the table must appear twice and therefore a table alias name must be used.
ANSI Standard
This returns all employees that have a supervisor assigned to them.
SELECT Employees.LastName,
Employees.FirstName,
Supervisors.LastName,
Supervisors.FirstName
FROM Employees
INNER JOIN Employees AS Supervisors
ON Employees.EmployeeID = Supervisors.ReportsTo
Alternative
SELECT Employees.LastName,
Employees.FirstName,
Supervisors.LastName,
Supervisors.FirstName
FROM Employees,
Employees Supervisors
WHERE Employees.EmployeeID = Supervisors.ReportsTo
In Access design view you can show this relationship by adding the table to the table pane twice.
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext