Hello i have the following models in my application:
User.php
<?php namespace App\Models;
use Illuminate\Auth\Authenticatable;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Auth\Passwords\CanResetPassword;
use Illuminate\Contracts\Auth\Authenticatable as AuthenticatableContract;
use Illuminate\Contracts\Auth\CanResetPassword as CanResetPasswordContract;
use Kodeine\Acl\Traits\HasRole;
class User extends Model implements AuthenticatableContract, CanResetPasswordContract {
use Authenticatable, CanResetPassword, HasRole;
/**
* The database table used by the model.
*
* @var stringSS
*/
protected $table = 'users';
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = ['name', 'email', 'password', 'is_active'];
/**
* The attributes excluded from the model's JSON form.
*
* @var array
*/
protected $hidden = ['password', 'remember_token'];
public function customer_details()
{
return $this->hasOne('App\Models\CustomerDetails', 'user_id');
}
}
CustomerDetails.php
<?php namespace App\Models;
use Illuminate\Database\Eloquent\Model;
class CustomerDetails extends Model {
protected $table = 'customer_details';
protected $dates = ['created_at', 'updated_at', 'deleted_at'];
protected $appends = ['full_name'];
public function getFullNameAttribute()
{
return $this->attributes['first_name'] .' '. $this->attributes['last_name'];
}
public function user()
{
return $this->belongsTo('App\Models\User', 'user_id');
}
public function invoices() {
return $this->hasMany('App\Models\Invoices', 'customer_id');
}
}
Now i am trying to run the following query:
$user = User::select('email', 'phone')->where('id', Auth::user()->id)->with('customer_details')->first();
Now what i want it to do is to select only the email and phone number from my users table and first_name, last_name from my customer_details table but wheneve i try this it always returns customer_details as null, this function will be used on one page alone meaning there are other pages that may require all details but not this one so i want to create a separate eloquent relation to do this. I would like some help with this please.
via Chebli Mohamed
Aucun commentaire:
Enregistrer un commentaire