I have 4 MySQL tables, using PHP and Laravel 7
Now I want to display each member's single payment and all other deductions continuously. (Assume one person only has one payment)
The database structure is as follows
This is the HTML table I want to display
This is the query I'm using, but it duplicates the data.
$payments = Payment::leftJoin('members', 'payments.member_id', '=', 'members.id') ->leftJoin('payment_deductions', 'payments.id', '=', 'payment_deductions.payment_id') ->leftJoin('deductions', 'payment_deductions.deduction_id', '=', 'deductions.id') ->select( 'members.*', 'payment_deductions.*', ) ->orderBy("member_id", "ASC") ->get()->toArray();
The resulting array repeats each member based on its derivation.
Is there any way to better obtain this data? Something like a nested array of deductions for each member?
This is the model
member
namespace App; use IlluminateDatabaseEloquentModel; use CarbonCarbon; class Member extends Model { protected $fillable = [ 'full_name', 'email', 'created_by', ]; }
Payment
namespace App; use IlluminateDatabaseEloquentModel; class Payment extends Model { protected $fillable = [ 'member_id', 'total_amount', 'payable_amount', 'created_by', ]; public function deductions() { return $this->belongsToMany(Deduction::class,'payment_deductions')->withTimestamps(); } }
deduct
namespace App; use IlluminateDatabaseEloquentModel; class Deduction extends Model { protected $fillable = [ 'title', 'priority', 'created_by', ]; }
You are very close and on the right track when building the model, what you are missing is how to load the relationships without creating another query, if you look at the controller you will see the criteria for loading the relationships inside method. Hopefully this is a better concept to address your concerns.
For reference: https://laravel.com/ docs/9.x/eloquent-relationships#lazy-eager-loading
Doing this will also avoid future
N 1
problems, see What is the "N 1 selection problem" in ORM (Object Relational Mapping)? Details aboutN 1
Member Model
Payment Mode
Deduction model
Member Controller: