From 1f23fa7625293d7ba9c777787be64f8f8c654183 Mon Sep 17 00:00:00 2001 From: Filip Horvat Date: Fri, 23 Feb 2018 11:54:04 +0100 Subject: [PATCH] fix HasOneJoin current table primary key --- src/Traits/EloquentJoinTrait.php | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/src/Traits/EloquentJoinTrait.php b/src/Traits/EloquentJoinTrait.php index 2353fef..83dfdaf 100644 --- a/src/Traits/EloquentJoinTrait.php +++ b/src/Traits/EloquentJoinTrait.php @@ -88,8 +88,9 @@ private function performJoin($builder, $relations) $baseTable = $this->getTable(); $baseModel = $this; - $currentTable = $this->getTable(); $currentModel = $this; + $currentPrimaryKey = $this->getKeyName(); + $currentTable = $this->getTable(); foreach ($relations as $relation) { if ($relation == $column) { @@ -122,8 +123,8 @@ private function performJoin($builder, $relations) $keyRelated = $relatedRelation->getForeignKey(); $keyRelated = last(explode('.', $keyRelated)); - $builder->leftJoin($joinQuery, function ($join) use ($relatedTableAlias, $keyRelated, $currentTable, $relatedPrimaryKey, $relatedModel) { - $join->on($relatedTableAlias . '.' . $keyRelated, '=', $currentTable . '.' . $relatedPrimaryKey); + $builder->leftJoin($joinQuery, function ($join) use ($relatedTableAlias, $keyRelated, $currentTable, $relatedPrimaryKey, $relatedModel, $currentPrimaryKey) { + $join->on($relatedTableAlias . '.' . $keyRelated, '=', $currentTable . '.' . $currentPrimaryKey); $this->leftJoinQuery($join, $relatedModel, $relatedTableAlias); }); @@ -132,8 +133,9 @@ private function performJoin($builder, $relations) } } - $currentTable = $relatedTableAlias; $currentModel = $relatedModel; + $currentPrimaryKey = $relatedPrimaryKey; + $currentTable = $relatedTableAlias; $this->joinedTables[$relation] = $relatedTableAlias; }