我使用php artisan make:migration
命令创建一个表。之后,我编辑迁移文件以放置列并插入标准数据。
在我运行php migrate:referesh
命令并且一切正常后,我转到数据库,表格中有正确的名称和数据。
在数据库中,表名是rolesStems。
我创建了这样的模型:
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class RolesStems extends Model
{
protected $fillable = ['id', 'value', 'order', 'active','id_stem', 'id_role'];
}
在我的控制器中我这样做:
use App\RolesStems as RolesStem;
RolesStem::select('value')->where('active', '=', 1)->where('id_stem', '=', 1)->orderBy('id_role', 'asc')->get());
我有这个错误:
SQLSTATE[42S02]: Base table or view not found: 1146 Table 'dbname.roles_stems' doesn't exist (SQL: select `value` from `roles_stems` where `active` = 1 and `id_stem` = 1 order by `id_role` asc)
它将未知的表名称设置为roles_stems,为什么?
我以相同的方式对其他表执行此操作,但是使用此表会发生这种情况。
有什么问题?
答案 0 :(得分:4)
因为您没有关注Laravel naming conventions,所以您应该手动定义表格:
protected $table = 'your_table_name';
答案 1 :(得分:3)
对于名称为rolesStems
的表格,您的model
必须具有名称RolesStem
因此,请更改以下行:
class RolesStems extends Model
到
class RolesStem extends Model
这是默认的Laravel命名约定:Reference
如果您不想遵循此命名约定,请将以下代码放入模型中:
protected $table = 'your_table_name';
这样您的模型就会指向your_table_name
答案 2 :(得分:1)
@ user3242861,默认情况下,Laravel尝试根据您的模型类名称查找表格,例如:您的类“RolesStems”然后它将尝试查找表“roles_stems”,因此如果它不可用,那么它将给表或视图不存在。
要覆盖默认功能,您可以在模型类中明确定义表名,如下所示。
protected $table = 'your_table_name';