Я работаю с отношениями laravel многие ко многим. В моем начальном файле базы данных я добавляю множественную вставку в pivot_table
, используя метод attach()
, например -
$role_admin->permissions()->attach(array($permission_create,$permission_read,$permission_update,$permission_delete));
Но когда я запускаю db:seed artisan command
, он показывает эту ошибку.
PDOException::("SQLSTATE[HY000]: General error: 1366 Incorrect integer value: '{"id":1,"name":"Create","slug":"Create","description":"This is basic Create Permission","created_at":"2018-12-17 05:23:31","upda' for column 'permission_id' at row 1")
если я использую sync()
вместо attach()
, покажите эту ошибку.
ErrorException : Illegal offset type
Теперь я хочу знать, как я могу одновременно использовать несколько значений в моем permisson_role
pivot Table
Вот мой образец RoleTableSeeder
...
class RoleTableSeeder extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
$permission_create=Permission::where('slug','Create')->first();
$permission_read=Permission::where('slug','Read')->first();
$permission_update=Permission::where('slug','Update')->first();
$permission_delete=Permission::where('slug','Delete')->first();
$role_admin=new Role;
$role_admin->name = "Admin";
$role_admin->slug=ucfirst("admin");
$role_admin->description = "This is Super-Admin Role";
$role_admin->save();
$role_admin->permissions()->attach(array($permission_create,$permission_read,$permission_update,$permission_delete));
//$role_admin->permissions()->sync(array($permission_create,$permission_read,$permission_update,$permission_delete));
}
}
->first()
не возвращает идентификатор, вы должны использовать его так: ->first()->id