Joins

Learn how to perform joins

Joins are used to combine rows from two or more tables, based on a common field between them. Opis Database allows you to perform four type of joins: INNER join by using the join method, LEFT join by using the leftJoin method, RIGHT join by using the rightJoin method and FULL join by using the fullJoin method.

Performing a join is done in a similar manner for all four types of joins. All join methods accepts two arguments: the first argument represents the joined table and the second argument must be an anonymous callback function, which will receive as an argument an object that will be further used to set the join’s conditions to be met.

Adding a join condition is done by using the on method. This methods accepts two arguments, representing the two columns on which the join will be performed, and optionally a third argument representing the comparison operator which can be one of the following: =, !=, >, <, >= and <=. If no comparison operator is specified, the = operator will be used by default.

$result = $db->from('users')
             ->join('profiles', function($join){
                $join->on('users.id', 'profiles.id');
             })
             ->select()
             ->all();
SELECT * FROM `users` INNER JOIN `profiles` ON `users`.`id` = `profiles`.`id`

Adding multiple join conditions is done by using the andOn and orOn method. Depending on which method you use, the join condition will be combined with the previous declared join condition using the AND or the OR operator.

To add an additional condition to your join expression, that combines with the previous declared condition by using an AND operator, use the andOn method.

$result = $db->from('users')
             ->join('profiles', function($join){
                $join->on('users.id', 'profiles.id')
                     ->andOn('users.email', 'profile.primary_email');
             })
             ->select()
             ->all();
SELECT * FROM `users`
    INNER JOIN `profiles`
        ON `users`.`id` = `profiles`.`id`
        AND `users`.`email` = `profile`.`primary_email`

To add an additional condition to your join expression, that combines with the previous declared condition by using an OR operator, use the orOn method.

$result = $db->from('users')
             ->join('profiles', function($join){
                $join->on('users.id', 'profiles.id')
                     ->orOn('users.email', 'profile.primary_email');
             })
             ->select()
             ->all();
SELECT * FROM `users`
    INNER JOIN `profiles`
        ON `users`.`id` = `profiles`.`id`
        OR `users`.`email` = `profile`.`primary_email`

You can also group your join conditions, by passing as an argument to the on, andOn and orOn methods, an anonymous callback function.

$result = $db->from('users')
             ->join('profiles', function($join){
                $join->on('users.id', 'profiles.id')
                     ->andOn(function($join){
                        $join->on('users.email', 'profiles.primary_email')
                             ->orOn('users.email', 'profiles.secondary_email');
                     });
             })
             ->select()
             ->all();
SELECT * FROM `users`
    INNER JOIN `profiles`
        ON `users`.`id` = `profiles`.`id`
        AND (`users`.`email` = `profiles`.`primary_email`
                OR
             `users`.`email` = `profiles`.`secondary_email`)

Aliasing the table name used within a join, is done by passing a key => value mapped array to the used join method, where the key represents the table’s name and the value represents the alias name.

$result = $db->from('users')
             ->join(['profiles' => 'p'], function($join){
                $join->on('users.id', 'p.id');
             })
             ->select()
             ->all();
SELECT * FROM `users` INNER JOIN `profiles` AS `p` ON `users`.`id` = `p`.`id`