我正在执行一个简单的插入,我已经执行了很多次,没有任何问题,并且由于一些奇怪的原因它不工作,我得到了这个错误消息:
error: {type: "ErrorException", message: "Array to string conversion",…}
file: "C:\wamp\www\studentreg2\vendor\laravel\framework\src\Illuminate\Database\Grammar.php"
line: 33
message: "Array to string conversion"
type: "ErrorException"下面是我的代码:
$advisorCheck = AdvisorCheck::create([
'status' => Input::get('status'),
'application_id' => Input::get('id'),
'user_id' => Auth::id()
]);AdvisorCheck模型使用的advisor_check表的迁移看起来很好,所有外键都是无符号的,并且在phpmyadmin中正确地显示了关系,来自输入::get的所有值都是字符串,模型将正确的字段设置为可填充的(status,application_id,user_id)。
我甚至尝试过在php artisan tinker中这样做:
AdvisorCheck::create([ 'status' => 'returned', 'application_id' => '3', 'user_id' => '4']);我得到了这个响应:数组到字符串的转换
我也尝试过这种方法,并得到了相同的错误:
$advisorCheck = new AdvisorCheck;
$advisorCheck->status = Input::get('status');
$advisorCheck->application_id = Input::get('id');
$advisorCheck->user_id = Auth::id();
$advisorCheck->save();型号代码:
<?php
class AdvisorCheck extends \Eloquent {
protected $fillable = ['status', 'application_id', 'user_id'];
protected $table = ['advisor_check'];
}如果您需要查看更多代码,请联系我们。
非常感谢任何能提供帮助的人!
发布于 2014-12-17 20:13:51
如您在表属性中所示的示例中所示,Laravel docs属性是一个字符串,而不是一个数组
protected $table = 'advisor_check';这是完全有道理的,因为雄辩的模型本身并不支持多个表。
发布于 2014-12-17 20:14:18
$table应为字符串而不是数组
<?php
class AdvisorCheck extends \Eloquent {
protected $fillable = ['status', 'application_id', 'user_id'];
protected $table = 'advisor_check';
}发布于 2021-12-31 07:42:34
如果我们在laravel模型中给出表名,比如array:
protected $table = ['thoughts'];那么它就会产生错误。
因此,您应该以字符串形式给出表名,如下所示:
protected $table = 'thoughts';https://stackoverflow.com/questions/27524908
复制相似问题