Как сделать JOINTURE (соединение) в laravel

У меня есть две таблицы SALARIES и POINTAGES, и между ними есть отношение hasMany ownTo, я хочу отобразить для каждой POINTAGE соответствующую SALARIES, но это дает мне пустую таблицу данных. консультант.blade.php

@foreach($pointages as $pointage)
<tr>
  <td>{{ $pointage->datep }}</td>
  <td>{{ $pointage->chantier }}</td>
  <td>{{ $pointage->ouvrage }}</td>
  <td>{{ $pointage->nbrj }}</td>
  <td>{{ $pointage->solde }}</td>
  <td>{{ $pointage->salarie->nom }}</td>
</tr>
@endforeach

Pointage.php

 protected $fillable = [
  'salarie_id', 'datep', 'solde', 'nbrj' , 'ouvrage' , 'chantier' , 'prime' ,
];
 public function salarie(){
   return $this->belongsTo('App\Salarie');
 }

Зарплата.php

public function pointages(){
  return $this->hasMany('App\Pointage');
}

Миграция точки:

public function up(){
  Schema::table('pointages', function (Blueprint $table) {
    $table->integer('salarie_id')->unsigned()->after('id');
    $table->foreign('salarie_id')->references('id')->on('salaries');  
  });
}

SalarieController.php

 public function consulter()
     {
      $salaries = Salarie::with('pointages')->get();
      $pointages = Pointage::with(["salaries"])->has("salarie")->get();
      return view('salarie.consulter', compact('salaries','pointages'));
    }
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
0
44
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Некоторые вещи, которые вы могли бы попробовать:

  1. Я не уверен, имеет ли это значение, но вы можете попробовать удалить скобки в de with() вот так Pointage::with("salaries")->has("salarie")->get();
  2. Еще одна вещь, которую вы должны проверить, верны ли первичный и внешний ключи Salarie и Pointage. Документация Laravel указывает следующее:

    In the example above, Eloquent will try to match the user_id from the Phone model to an id on the User model. Eloquent determines the default foreign key name by examining the name of the relationship method and suffixing the method name with _id. However, if the foreign key on the Phone model is not user_id, you may pass a custom key name as the second argument to the belongsTo method.

Ответ принят как подходящий

Вам необходимо определить явные функции отношений:

// app\Salarie.php
class Salarie extends Model
{
    protected $fillable = ['nome'];
    public function pointages(){
        return $this->hasMany('App\Pointage','salarie_id','id');
    }
}
// app\Pointage.php
class Pointage extends Model
{
    protected $fillable = [
        'salarie_id', 'datep', 'solde', 'nbrj' , 'ouvrage' , 'chantier' , 'prime' ,
      ];
    public function salarie(){
        return $this->belongsTo('App\Salarie');
    }
}

И используйте, как показано ниже, чтобы проконсультироваться со всеми точками, связанными с таблицей зарплат:

// app\Http\Controllers\SalarieController.php
class SalarieController extends Controller
{
    public function consulter()
     {
        // test your model with this simple query
        // $salaries = Salarie::find(1);
        // $pointages = $salaries->pointages()->get();
        // return view('salarie.consulter', compact('pointages'));

        // if the upon test runs well, the follow codes will work 
        $salaries_ids = Salarie::with('pointages')->pluck('id');
        $pointages  = Pointage::whereHas('salarie', function($query) use ($salaries_ids) {
            $query->whereIn('salarie_id', $salaries_ids);
        })->get();
        return view('salarie.consulter', compact('pointages'));
    }
}

Надеюсь, это поможет, спросите меня, если вам нужно!

Другие вопросы по теме