[Vuejs]-Retrieving data from hasMany Relationship

1👍

Try :

 public function index()
{
    $personas = Persona::with('residentes')->get();
    dd($personas);
       
}

If you want to search using some keys inside the residentes relationship you can use whereHas

Persona::with('residentes')
       ->whereHas('residentes',function($residente){
           return $residente->where('column_name',$value);
         })->get();

Also try to mention the local_key and the foreign_key in the relationship itself reference : https://laravel.com/docs/9.x/eloquent-relationships

return $this->hasMany(Comment::class, 'foreign_key', 'local_key');

0👍

Please try the following in the place of key give actual field names.

//in the Persona class
    
public function residentes()
{
   return $this->hasMany(Residente::class, 'foreign_key', 'local_key');
}
    
//in the Residente class
    
public function persona()
{
    return $this->belongsTo(Persona::class,'foreign_key', 'owner_key');
}
    
    
//in the PersonasController
    
public function index()
{
    $personas = Persona::with('residentes')->get();
    foreach($personas as $person){
       echo "<pre>";
       print_r($person->residentes()->get()->toArray());
     }
}

Leave a comment