Download the PHP package hungcrush/compoships without Composer
On this page you can find all versions of the php package hungcrush/compoships. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download hungcrush/compoships
More information about hungcrush/compoships
Files in hungcrush/compoships
Package compoships
Short Description Laravel relationships with support for composite/multiple keys
License MIT
Informations about the package compoships
Compoships
Compoships offers the ability to specify relationships based on two (or more) columns in Laravel's Eloquent ORM. The need to match multiple columns in the definition of an Eloquent relationship often arises when working with third party or pre existing schema/database.
The problem
Eloquent doesn't support composite keys. As a consequence, there is no way to define a relationship from one model to another by matching more than one column. Trying to use where clauses
(like in the example below) won't work when eager loading the relationship because at the time the relationship is processed $this->team_id is null.
Related discussions:
- Relationship on multiple keys
- Querying relations with extra conditions not working as expected
- Querying relations with extra conditions in Eager Loading not working
- BelongsTo relationship with 2 foreign keys
- Laravel Eloquent: multiple foreign keys for relationship
- Laravel hasMany association with multiple columns
Installation
The recommended way to install Compoships is through Composer
Usage
Using the Awobaz\Compoships\Database\Eloquent\Model
class
Simply make your model class derive from the Awobaz\Compoships\Database\Eloquent\Model
base class. The Awobaz\Compoships\Database\Eloquent\Model
extends the Eloquent
base class without changing its core functionality.
Using the Awobaz\Compoships\Compoships
trait
If for some reasons you can't derive your models from Awobaz\Compoships\Database\Eloquent\Model
, you may take advantage of the Awobaz\Compoships\Compoships
trait. Simply use the trait in your models.
Note: To define a multi-columns relationship from a model A to another model B, both models must either extend Awobaz\Compoships\Database\Eloquent\Model
or use the Awobaz\Compoships\Compoships
trait
Syntax
... and now we can define a relationship from a model A to another model B by matching two or more columns (by passing an array of columns instead of a string).
We can use the same syntax to define the inverse of the relationship:
Example
As an example, let's pretend we have a task list with categories, managed by several teams of users where:
- a task belongs to a category
- a task is assigned to a team
- a team has many users
- a user belongs to one team
- a user is responsible for one category of tasks
The user responsible for a particular task is the user currently in charge for the category inside the team.
Again, same syntax to define the inverse of the relationship:
Supported relationships
Compoships only supports the following Laravel's Eloquent relationships:
- hasOne
- HasMany
- belongsTo
Also please note that while nullable columns are supported by Compoships, relationships with only null values are not currently possible.
Support for nullable columns in 2.x
Version 2.x brings support for nullable columns. The results may now be different than on version 1.x when a column is null on a relationship, so we bumped the version to 2.x, as this might be a breaking change.
Disclaimer
Compoships doesn't bring support for composite keys in Laravel's Eloquent. This package only offers the ability to specify relationships based on more than one column. We believe that all models' tables should have a single primary key. But there are situations where you'll need to match many columns in the definition of a relationship even when your models' tables have a single primary key.
Contributing
Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests.
Versioning
We use SemVer for versioning. For the versions available, see the tags on this repository.
Unit Tests
In order to run the test suite, install the development dependencies:
Then, run the following command:
Authors
- Claudin J. Daniel - Initial work
Sponsored by
- StockTreats - Stock Market Insights With Trading Tips And Tricks
- Awobaz - Web/Mobile agency based in Montreal, Canada
License
Compoships is licensed under the MIT License.
All versions of compoships with dependencies
illuminate/database Version ~5.4|~6.0|~7.0|~8.0
illuminate/console Version ~5.4|~6.0|~7.0|~8.0
illuminate/support Version ~5.4|~6.0|~7.0|~8.0
illuminate/cache Version ~5.4|~6.0|~7.0|~8.0