Set eloquent relationships with table that contains comma separated values as a foreign key
Get package using composer :
composer require ghanuz/relations
You have to extends GhanuZ\Model
class instead of Illuminate\Database\Eloquent\Model
<?php
namespace App;
use GhanuZ\Model;
class Test extends Model
{
//
}
Like in Laravel, Users
model not extending Model
class.
So you can use trait
.
GhanuZ\FindInSet\FindInSetRelationTrait
Example:
<?php
namespace App;
use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;
use GhanuZ\FindInSet\FindInSetRelationTrait;
class User extends Authenticatable
{
use Notifiable, FindInSetRelationTrait;
public function city ()
{
return $this->FindInSetOne( 'App\City', 'city_ids', 'id', 1);
}
public function state ()
{
return $this->FindInSetOne( 'App\State', 'city_ids', 'id', 2);
}
public function country ()
{
return $this->FindInSetOne( 'App\Country', 'city_ids', 'id', 3);
}
public function hobbies ()
{
return $this->FindInSetMany( 'App\Hobbies', 'hobbies_id', 'id');
}
}
public function order_product (){
return $this->FindInSetMany( CLASS_NAME, FOREIGN_KEY, LOCAL_KEY);
}
public function order_product (){
return $this->FindInSetOne( CLASS_NAME, FOREIGN_KEY, LOCAL_KEY);
}
If you have an address
table schema and stored city_ids
like city_id,state_id,country_id
.
Now, you want to find only city_id
, you will do as :
select * from address where FIND_IN_CITY( 2, city_ids ) = 1;// Here $index = 1
Like, for state_id
:
select * from address where FIND_IN_CITY( 1, city_ids ) = 2;// Here $index = 2
Like, for country_id
:
select * from address where FIND_IN_CITY( 5, city_ids ) = 3;// Here $index = 3
public function order_product (){
return $this->FindInSetMany( CLASS_NAME, FOREIGN_KEY, LOCAL_KEY, Number);
}