为何laravel5的orm中setTable没有效果

use Illuminate\Database\Eloquent\Model as Eloquent;
class MessageModel extends Eloquent{
    public $table = 'message';
    
    public function getModel($tableName){
    
       return $this->setTable($tableName);
    }
}

报错:

[2016-12-18 18:27:33] production.ERROR: PDOException: SQLSTATE[42S02]: Base table or view not found: 1146 Table 'message' doesn't exist in vendor/laravel/framework/src/Illuminate/Database/Connection.php:457

因为消息表示分表的所以想通过一个model操作所有的分表的表

阅读 4.5k
1 个回答
✓ 已被采纳新手上路,请多包涵

今天发现这个是自己使用的问题因为我使用了create静态方法我们可以看到基类的定义

/**
     * Save a new model and return the instance.
     *
     * @param  array  $attributes
     * @return static
     */
    public static function create(array $attributes = [])
    {
        $model = new static($attributes);

        $model->save();

        return $model;
    }
    

所以由此看出凡是改过表名的model都不能再使用静态方法。只能通过其他方法实现

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题