我有一些逻辑建议。我正在创建一个系统,用户可以在该系统上登录并注册他们在活动中的参与。他们可以多次参加活动。做这个的最好方式是什么?我想确保自己可以用雄辩的语言,而不是创建自己的函数。
我在想...
用户:
id
活动:
id
name
参加:
id
user_id
activity_id
time_at_activity
我希望以后能够执行以下操作:$user->participations->where('activity_id', 3)
例如。
设置此设置的最佳方法是什么?我想到了..
用户:hasMany->参与人数
活动:belongsTo->参与
参与:hasMany->活动和belongsTo->用户
看起来正确吗?
/**
* Indicate that the model belongs to a user.
*
* @see \App\Model\User
*
* @return BelongsTo
*/
public function user()
{
return $this->belongsTo(User::class);
}
/**
* Indicate that the model belongs to many activity participations.
*
* @see \App\Model\Activity
*
* @return BelongsTo
*/
public function participations()
{
return $this->belongsToMany(Activity::class, 'participations');
}
$user->participations()->attach($activity);
您可能想添加相互关系。这些可以分为特征以供代码重用。 ->attach(['participated_at' => now()])
您可以使用Many-to-Many关系。
使用Participation
作为数据透视表。将关系定义为
/* in User */
public function activity()
{
return $this->belongsToMany('App\Models\Activitys','participation','user_id','activity_id')->as('participation')->withPivot('time_at_activity');
}
/* in Activity */
public function user()
{
return $this->belongsToMany('App\Models\Users','participation','activity_id','user_id')->as('participation')->withPivot('time_at_activity');
}
// App\User
public function participations()
{
return $this->hasMany('App\Participation');
}
// You may create App\Participation Model
// App\Participation
public function user()
{
return $this->belongsTo('App\User');
}
// Controller
$userParticipations = $user->participations->where('activity_id', 3);
// eager loading version
$userWithParticipations = $user->with(['participations' => function($q) { $q->where('activity_id', 3) }])->get();