Download the PHP package homedoctor-es/eloquent-has-by-non-dependent-subquery without Composer
On this page you can find all versions of the php package homedoctor-es/eloquent-has-by-non-dependent-subquery. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package eloquent-has-by-non-dependent-subquery
Eloquent Has By Non-dependent Subquery
Convert has()
and whereHas()
constraints to non-dependent subqueries.
NOTICE: Postgres' optimizer is very smart and covers JOIN optimization for dependent (correlated) subqueries. Therefore, this library is mainly targeted at MySQL which has a poor optimizer.
Requirements
- PHP:
^7.3 || ^8.0
- Laravel:
^6.0 || ^7.0 || ^8.0 || ^9.0
Installing
Suggestion
You can install wimski/laravel-ide-helper-hook-eloquent-has-by-non-dependent-subquery to work with Laravel IDE Helper.
Motivation
Suppose you have the following relationship:
If you use has()
constraints, your actual query would have dependent subqueries.
These subqueries may cause performance degradations.
This package provides Illuminate\Database\Eloquent\Builder::hasByNonDependentSubquery()
macro to solve this problem:
you can easily transform dependent subqueries into non-dependent ones.
API
Signature
Arguments
$relationMethod
A relation method name that returns a Relation
instance except MorphTo
.
You can pass nested relations as an array or a string with dot-chain syntax.
$constraints
Additional callable
constraints for relations that take Illuminate\Database\Eloquent\Relation
as the first argument.
If you are using a union type as of PHP 8.0, the order of types does not matter.
The first closure corresponds to comments
and the second one corresponds to author
.
Feature Comparison
Feature | mpyw/eloquent-has-by-join |
mpyw/eloquent-has-by-non-dependent-subquery |
---|---|---|
Minimum Laravel version | 5.6 | 5.8 |
Argument of optional constraints | Illuminate\Database\Eloquent\Builder |
Illuminate\Database\Eloquent\Relations\* ( Builder can be also accepted by specifying argument type) |
Compoships support | ✅ | ❌ |
No subqueries | ✅ | ❌ (Performance depends on database optimizers) |
No table collisions | ❌ (Sometimes you need to give aliases) |
✅ |
No column collisions | ❌ (Sometimes you need to use qualified column names) |
✅ |
OR conditions | ❌ | ✅ |
Negative conditions | ❌ | ✅ |
Counting conditions | ❌ | ❌ |
HasOne |
✅ | ✅ |
HasMany |
❌ | ✅ |
BelongsTo |
✅ | ✅ |
BelongsToMany |
❌ | ✅ |
MorphOne |
✅ | ✅ |
MorphMany |
❌ | ✅ |
MorphTo |
❌ | ❌ |
MorphMany |
❌ | ✅ |
MorphToMany |
❌ | ✅ |
HasOneThrough |
❌ | ✅ |
HasManyThrough |
❌ | ✅ |
All versions of eloquent-has-by-non-dependent-subquery with dependencies
illuminate/database Version ^5.8 || ^6.0 || ^7.0 || ^8.0 || ^9.0
illuminate/support Version ^5.8 || ^6.0 || ^7.0 || ^8.0 || ^9.0