Laravel - 表不存在

时间:2017-03-16 11:49:02

标签: php mysql laravel database-migration

我使用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,为什么?

我以相同的方式对其他表执行此操作,但是使用此表会发生这种情况。

有什么问题?

3 个答案:

答案 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';