【发布时间】:2017-08-28 10:21:05
【问题描述】:
我遇到了这个错误,我检查的谷歌搜索结果都没有与我的问题相似。
我有一个包含 Deal、User 和 Matches 类的应用程序
一笔交易有很多匹配项。 一个用户有很多匹配项。 一个用户有很多交易。
我正在尝试使用我的 Deal 对象创建一个新的匹配
$deal->matches()->create(['user_id'=>$id]);
这是我的匹配类,我已经定义了所有需要的关系
class Match extends Model
{
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $guarded = [];
public $timestamps = false;
public $expired_on = "";
public static function boot()
{
parent::boot();
static::creating(function ($model) {
$model->matched_on = $model->freshTimestamp();
});
}
public function __construct(){
$d = (new \DateTime($this->matched_on))->modify('+1 day');
$this->expired_on = $d->format('Y-m-d H:i:s');
}
/**
* Get the user that owns the match.
*/
public function user()
{
return $this->belongsTo('App\User');
}
/**
* Get the deal that owns the match.
*/
public function deal()
{
return $this->belongsTo('App\Deal');
}
}
当我尝试创建新匹配时,我不断收到此错误。
Connection.php 第 647 行中的 QueryException: SQLSTATE[HY000]:一般错误:1364 字段'user_id'没有默认值(SQL:插入
matches(deal_id)值(1))
我的守卫是一个空数组,可能是什么问题?
【问题讨论】:
-
我不明白为什么matches有一个模型类,如果它是一个数据透视表laravel.com/docs/5.0/eloquent#working-with-pivot-tables
-
这通常是在您不插入某个不能为NULL或没有默认值的字段时生成的。所以你的'user_id'不会被插入
-
@Cr1xus,是的,我的 'user_id' 没有被插入,我现在的问题是为什么会这样,因为我的 create 方法中有它。
标签: php mysql laravel laravel-5.4