Вход Регистрация
Файл: vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasOne.php
Строк: 214
<?php

namespace IlluminateDatabaseEloquentRelations;

use 
IlluminateContractsDatabaseEloquentSupportsPartialRelations;
use 
IlluminateDatabaseEloquentBuilder;
use 
IlluminateDatabaseEloquentCollection;
use 
IlluminateDatabaseEloquentModel;
use 
IlluminateDatabaseEloquentRelationsConcernsCanBeOneOfMany;
use 
IlluminateDatabaseEloquentRelationsConcernsComparesRelatedModels;
use 
IlluminateDatabaseEloquentRelationsConcernsSupportsDefaultModels;
use 
IlluminateDatabaseQueryJoinClause;

class 
HasOne extends HasOneOrMany implements SupportsPartialRelations
{
    use 
ComparesRelatedModelsCanBeOneOfManySupportsDefaultModels;

    
/**
     * Get the results of the relationship.
     *
     * @return mixed
     */
    
public function getResults()
    {
        if (
is_null($this->getParentKey())) {
            return 
$this->getDefaultFor($this->parent);
        }

        return 
$this->query->first() ?: $this->getDefaultFor($this->parent);
    }

    
/**
     * Initialize the relation on a set of models.
     *
     * @param  array  $models
     * @param  string  $relation
     * @return array
     */
    
public function initRelation(array $models$relation)
    {
        foreach (
$models as $model) {
            
$model->setRelation($relation$this->getDefaultFor($model));
        }

        return 
$models;
    }

    
/**
     * Match the eagerly loaded results to their parents.
     *
     * @param  array  $models
     * @param  IlluminateDatabaseEloquentCollection  $results
     * @param  string  $relation
     * @return array
     */
    
public function match(array $modelsCollection $results$relation)
    {
        return 
$this->matchOne($models$results$relation);
    }

    
/**
     * Add the constraints for an internal relationship existence query.
     *
     * Essentially, these queries compare on column names like "whereColumn".
     *
     * @param  IlluminateDatabaseEloquentBuilder  $query
     * @param  IlluminateDatabaseEloquentBuilder  $parentQuery
     * @param  array|mixed  $columns
     * @return IlluminateDatabaseEloquentBuilder
     */
    
public function getRelationExistenceQuery(Builder $queryBuilder $parentQuery$columns = ['*'])
    {
        if (
$this->isOneOfMany()) {
            
$this->mergeOneOfManyJoinsTo($query);
        }

        return 
parent::getRelationExistenceQuery($query$parentQuery$columns);
    }

    
/**
     * Add constraints for inner join subselect for one of many relationships.
     *
     * @param  IlluminateDatabaseEloquentBuilder  $query
     * @param  string|null  $column
     * @param  string|null  $aggregate
     * @return void
     */
    
public function addOneOfManySubQueryConstraints(Builder $query$column null$aggregate null)
    {
        
$query->addSelect($this->foreignKey);
    }

    
/**
     * Get the columns that should be selected by the one of many subquery.
     *
     * @return array|string
     */
    
public function getOneOfManySubQuerySelectColumns()
    {
        return 
$this->foreignKey;
    }

    
/**
     * Add join query constraints for one of many relationships.
     *
     * @param  IlluminateDatabaseQueryJoinClause  $join
     * @return void
     */
    
public function addOneOfManyJoinSubQueryConstraints(JoinClause $join)
    {
        
$join->on($this->qualifySubSelectColumn($this->foreignKey), '='$this->qualifyRelatedColumn($this->foreignKey));
    }

    
/**
     * Make a new related instance for the given model.
     *
     * @param  IlluminateDatabaseEloquentModel  $parent
     * @return IlluminateDatabaseEloquentModel
     */
    
public function newRelatedInstanceFor(Model $parent)
    {
        return 
$this->related->newInstance()->setAttribute(
            
$this->getForeignKeyName(), $parent->{$this->localKey}
        );
    }

    
/**
     * Get the value of the model's foreign key.
     *
     * @param  IlluminateDatabaseEloquentModel  $model
     * @return mixed
     */
    
protected function getRelatedKeyFrom(Model $model)
    {
        return 
$model->getAttribute($this->getForeignKeyName());
    }
}
Онлайн: 0
Реклама