在 MongoDB 和 laravel 中的唯一值验证中未找到基础 Table

Base Table not found on unique value validation in MongoDB with laravel

我正在使用 laravel 5.3 和 jenssegers/laravel-mongodb 软件包来管理 mongodb 连接。

每次用户发送请求在我的控制器中注册网站时,我都想检查它是否唯一,然后让用户注册 his/her 网站域。

我写了下面的验证代码,但我得到的结果是:

SQLSTATE[42S02]: Base table or view not found: 1146 Table 'iranad.seat' doesn't exist (SQL: select count(*) as aggregate from `seat` where `domain` = order.org)

我的控制器代码:

public function store(Request $request) {
    $seat = new Seat();

    $validator = Validator::make($request->all(), [
            'domain' => 'required|regex:/^([\da-z\.-]+)\.([a-z\.]{2,6})([\/\w \.-]*)*\/?$/|unique:seat', //validating user is entering correct url like : iranad.ir
            'category' => 'required',
    ]);

    if ($validator->fails()) {
        return response()->json($validator->messages(), 400);
    } else {
        try {
            $statusCode = 200;
            $seat->user_id = Auth::user()->id;
            $seat->url = $request->input('domain');
            $seat->cats = $request->input('category');
            $seat->filter = [];
            if($request->input('category') == 'all') {
                $obj['cats'] = 'false';
                $seat->target = $obj;
            } else {
                $obj['cats'] = 'true';
                $seat->target = $obj;
            }
            $seat->status = 'Waiting';
            $seat->save();
        } catch (\Exception $e) {
                $statusCode = 400;
        } finally {
                $response = \Response::json($seat, $statusCode);
                return $response;
        }
    }
}

我的座椅型号:

namespace App;

use Moloquent;
use Carbon\Carbon;

class Seat extends Moloquent {

    public function getCreatedAtAttribute($value) {
        return Carbon::createFromTimestamp(strtotime($value))
            ->timezone('Asia/Tehran')
            ->toDateTimeString();
    }
}

显然验证器正在检查域在 mysql 表中是否唯一导致此错误,如何更改我的验证过程以检查 mongodb 而不是 mysql?

我解决了这个问题,解决方案是您应该将 Moloquent 添加到您的模型并定义数据库连接:

namespace App\Models;

use Moloquent;
use Carbon\Carbon;

class Seat extends Moloquent
{
    protected $collection = 'seat';
    protected $connection = 'mongodb';
}