我在登录用户和他想加入的活动之间建立关系时遇到了一些问题。 我真的采取了许多步骤来做类似于我对角色用户所做的事情。但在这里我遇到了一些问题,因为我的用户使用模型用户,事件使用模型HomeModel和其他3个模型建立关系并连接到表SaveEvent。 有我的代码。我希望有人可以告诉我如何弄明白,因为我浪费了2天来解决我的问题:
模型HomeModel
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class HomeModel extends Model
{
protected $table = 'events'; // you may change this to your name table
public $timestamps = true; // set true if you are using created_at and updated_at
protected $primaryKey = 'id'; // the default is id
/**
* Is it an all day event?
*
* @return bool
*/
public function isAllDay()
{
return (bool)$this->day;
}
}
模型用户
<?php
namespace App;
use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;
class User extends Authenticatable
{
use Notifiable;
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'lastname', 'name', 'phonenumber', 'email', 'password', 'user_id' ,
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
'password', 'remember_token',
];
public function roles()
{
return $this->belongsToMany('App\Role', 'user_role', 'user_id', 'role_id');
}
public function hasAnyRole($roles)
{
if (is_array($roles)) {
foreach ($roles as $role) {
if ($this->hasRole($role)) {
return true;
}
}
} else {
if ($this->hasRole($roles)) {
return true;
}
}
return false;
}
public function hasRole($role)
{
if ($this->roles()->where('name', $role)->first()) {
return true;
}
return false;
}
public function events()
{
return $this->belongsToMany('App\SaveEvent')->withTimestamps();
}
}
模型SaveEvent
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class SaveEvent extends Model
{
public function users()
{
return $this->belongsToMany('App\User');
}
}
关系表
+------------+------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+------------+------------------+------+-----+---------+----------------+
| id | int(10) unsigned | NO | PRI | NULL | auto_increment |
| created_at | timestamp | YES | | NULL | |
| updated_at | timestamp | YES | | NULL | |
| users_id | int(10) unsigned | NO | MUL | NULL | |
| events_id | int(10) unsigned | NO | MUL | NULL | |
+------------+------------------+------+-----+---------+----------------+
public function acceptEvent($id)
{
$events_id = HomeModel::find($id);
$users_id = new SaveEvent;
$users_id->users_id=Auth::id();
$users_id->save();
$users_id->events()->attach($events_id);
return redirect()->back();
}
答案 0 :(得分:0)
您不需要模型来保存events
。这是一个多对多的关系所以使用数据透视表。
更改event
模型中的User
方法,如下所示:
public function events()
{
return $this->belongsToMany(HomeModel::class,'PIVOT_TABLE_NAME','user_id','events_id');->withTimestamps();
}
和HomeModel
:
public function users()
{
return $this->belongsToMany(User::class,'PIVOT_TABLE_NAME','events_id','user_id');
}
现在您可以使用$user->events->attach($events_id);