talentify / phalcon.eager-loading
Solves N+1 query problem in Phalcon Model
4.1.1
2022-08-24 20:22 UTC
Requires
- php: >=7.1
This package is auto-updated.
Last update: 2024-10-25 01:08:58 UTC
README
This package provides eager-loading support for Phalcon 1.3.* - 2.0.*.
Requires PHP 5.6, for PHP 5.3 support use php-5.3 branch
Phalcon 3.3 supported
Usage
The usage is similar to Laravel, I've implemented in a trait with
and load
methods, so within a model that uses that trait (Sb\Framework\Mvc\Model\EagerLoadingTrait
) you can do:
<?php use Sb\Framework\Mvc\Model\EagerLoading\Loader, Sb\Framework\Mvc\Model\EagerLoading\QueryBuilder; $robotsAndParts = Robot::with('Parts'); // Equivalent to: $robots = Robot::find(); foreach ($robots as $robot) { $robot->parts; // $robot->__get('parts') } // Or $robot = Robot::findFirst()->load('Parts'); // Equivalent to: $robot = Robot::findFirst(); $robots->parts; // $robot->__get('parts') // Because Robot::find() returns a resultset, so in that case this is solved with: $robots = Loader::fromResultset(Robot::find(), 'Parts'); # Equivalent to the second example // Multiple and nested relations can be used too $robots = Robot::with('Parts', 'Foo.Bar'); // And arguments can be passed to the find method $robots = Robot::with('Parts', 'Foo.Bar', ['limit' => 5]); // And constraints $robots = Robot::with( [ 'Parts', 'Foo.Bar' => function (QueryBuilder $builder) { // Limit Bar $builder->limit(5); } ], [ 'limit' => 5 ] ); // constraints with the Loader too $robots = Loader::fromResultset(Robot::find(), [ 'Foo.Bar' => function (QueryBuilder $builder) { $builder->where('Bar.id > 10'); } ]);
For more examples, return types etc visit the tests folder or take a look at the code, it's quite small.