我有这样的迁移:
Schema::create('provincias', function (Blueprint $table) {
$table->string('codigo', 2);
$table->string('nombre', 50);
$table->timestamp('creado');
$table->primary('codigo');
});
这是我的模型:
class Provincia extends Model
{
protected $primaryKey = 'codigo';
public $timestamps = false;
}
我运行迁移并保存数据,如下所示:
$provincia = new Provincia;
$provincia->codigo = "BA";
$provincia->nombre = "Buenos Aires";
$provincia->save();
问题是,当我获得所有内容并转储时:
$provincias = Provincia::all();
return $provincias;
主键"codigo“总是0,即使我检查数据库表,它也有正确的值:
{
codigo: 0,
nombre: "Buenos Aires",
creado: "2015-12-24 21:00:24"
}
发布于 2015-12-25 08:15:30
你可以尝试在你的模型上设置public $incrementing = false;
,这样eloquent就不会期望你的主键是一个自动增量的主键。
发布于 2019-05-20 02:37:50
您还可以设置主键的类型:
protected $keyType = 'string';
public $incrementing = false;
重要的注意事项。您应该添加第二行。$incrementing = false
。如果不这样做,则在模型上调用save()
后,键将为0。
https://stackoverflow.com/questions/34458985
复制相似问题