我通过以下方式从控制器操作中请求验证请求的值:
namespace App\Http\Requests;
use App\Http\Requests\Request;
class AccountsRequest extends Request {
/**
* Determine if the user is authorized to make this request.
*
* @return bool
*/
public function authorize() {
return TRUE;
}
public function rules() {
return [
'email' => 'email|required|max:255|unique:accounts',
'password' => 'min:6|required'
];
}
}
如果我使用默认数据库,一切都很好,但对于此验证,我需要检查其他数据库中的表。在配置中,我有两个数据库:
'connections' => [
'sqlite' => [
'driver' => 'sqlite',
'database' => database_path('database.sqlite'),
'prefix' => '',
],
'mysql' => [
'driver' => 'mysql',
'host' => env('DB_HOST', 'localhost'),
'database' => env('DB_DATABASE', 'sait'),
'username' => env('DB_USERNAME', 'root'),
'password' => env('DB_PASSWORD', ''),
'charset' => 'utf8',
'collation' => 'utf8_unicode_ci',
'prefix' => '',
'strict' => false,
],
'mysql2' => [
'driver' => 'mysql',
'host' => env('DB_HOST', 'localhost'),
'database' => env('DB_DATABASE', 'account'),
'username' => env('DB_USERNAME', 'root'),
'password' => env('DB_PASSWORD', ''),
'charset' => 'utf8',
'collation' => 'utf8_unicode_ci',
'prefix' => '',
'strict' => false,
],
当我打电话给验证时,它正在检查" unique"规则在我的默认数据库中,所以我需要更改它,但我无法在任何地方找到如何做到这一点。
答案 0 :(得分:5)
根据文档unique - Custom Database Connection 而不是
'email' => 'email|required|max:255|unique:accounts',
你需要做
'email' => 'email|required|max:255|unique:mysql2.accounts',
我猜对了它没有提到的mysql2。
答案 1 :(得分:0)
你是否在“独特”的文档中看到了这一点?规则?
600
您可以使用setConnection()方法指定您希望如何确定唯一性。