GA黄金甲

laravel 去掉povit

laravel 是一款盛行的 php web 框架,提供了一些很是利便的功效和工具,使得 web 开发变得越发简朴和快速。其中,pivot 是一个很是主要的功效,用于处置惩罚多对多关系。可是,在某些情形下,我们可能需要去掉 pivot。

为什么要去掉 Pivot?

在开发历程中,有时间泛起了 Pivot 的限制,我们可能需要对多对多关系举行更多的定制和控制。此时,去掉 Pivot 可以提供更大的无邪性。下面是一些常见的情形:

定制关系表的字段名称

Pivot 会自动天生一其中心表,其中包括两个外键和一个时间戳。在某些情形下,我们可能需要定制更多的字段,好比添加一个状态字段。这时间,去掉 Pivot,我们可以手动建设一其中心表,定制字段名称和类型。

控制关系表的建设和更新

当我们使用 Laravel 的 Pivot 功效时,若是关系表不保存,框架会自动建设。可是,在某些情形下,我们可能需要手动建设这个表,并在更新关系时举行更多的控制。去掉 Pivot 后,我们可以手动编写 SQL 语句,自由控制关系表的建设和更新。

处置惩罚重大的多对多关系

Laravel 的 Pivot 功效通常适用于简朴的多对多关系。可是,在一些重大的情形下,我们可能需要更多的定制和控制。好比,我们需要处置惩罚多重表格之间的多对多关系,或者需要在关系表中添加更多的字段举行处置惩罚。这时间,去掉 Pivot,我们可以凭证需要举行更多的构建和控制。

怎样去掉 Pivot?

去掉 Pivot 的要领有多种,下面先容两种常见的方法。

要领一:手动建设中心表

首先,在数据库中建设一其中心表。

CREATE TABLE `user_role` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`user_id` int(11) unsigned NOT NULL,
`role_id` int(11) unsigned NOT NULL,
`created_at` timestamp NULL DEFAULT NULL,
`updated_at` timestamp NULL DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

登录后复制

在模子中界说多对多关系

class User extends Model
{
public function roles()
{
return $this->belongsToMany(Role::class, 'user_role', 'user_id', 'role_id');
}
}

class Role extends Model
{
public function users()
{
return $this->belongsToMany(User::class, 'user_role', 'role_id', 'user_id');
}
}

登录后复制

在控制器中使用

$user = User::find(1);
$roles = $user->roles;

登录后复制

要领二:使用中心件

建设一其中心件

php artisan make:middleware SimplifyPivotMiddleware

登录后复制

在中心件中处置惩罚多对多关系

namespace AppHttpMiddleware;

use Closure;

class SimplifyPivotMiddleware
{
public function handle($request, Closure $next)
{
$user = $request->user;
$roles = $user->roles()->withTimestamps()->select('id', 'name')->get();
$user->setRelation('roles', $roles);
return $next($request);
}
}

登录后复制

在路由中使用中心件

Route::get('/user/{id}/roles', function ($id) {
$user = User::with('roles')->find($id);
return response()->json(['status' => 1, 'data' => $user->roles]);
})->middleware(SimplifyPivotMiddleware::class);

登录后复制

结论

Pivot 是 Laravel 处置惩罚多对多关系的一种很好的方法。可是,在某些情形下,我们可能需要去掉 Pivot,并手动建设中心表,或使用中心件来处置惩罚多对多关系。这样可以提供更大的无邪性和控制能力,但需要支付更多的编码和维护本钱。

以上就是laravel 去掉povit的详细内容,更多请关注本网内其它相关文章!

免责说明:以上展示内容泉源于相助媒体、企业机构、网友提供或网络网络整理,版权争议与本站无关,文章涉及看法与看法不代表GA黄金甲滤油机网官方态度,请读者仅做参考。本文接待转载,转载请说明来由。若您以为本文侵占了您的版权信息,或您发明该内容有任何涉及有违公德、冒犯执法等违法信息,请您连忙联系GA黄金甲实时修正或删除。

相关新闻

联系GA黄金甲

18523999891

可微信在线咨询

事情时间:周一至周五,9:30-18:30,节沐日休息

QR code
【网站地图】【sitemap】