Laravel unique规则使用

laravel版本 5.5
laravel的unique的用法:

        $customer_type = request('customer_type', 1);
        $attributes = request()->validate([
            'gender' => 'required|min:0|max:3',
            'chinese_name' => 'nullable|min:2',
            'english_name' => 'nullable|min:3',
            'area_phone_number' => 'required|numeric',
            'telephone' => 'required|numeric',
            'email' => ['required', 'email', Rule::unique('customer')->ignore(request('id'))->where(function ($query) {
                $query->whereNotIn('status', [4]);
            })],
            // 'email' => 'required|email|unique:customer,email,' . request('id'),
            'password' => 'nullable|string|min:6',
            'concurrent_login_num' => 'required|min:1|integer',
            'child_age' => 'nullable|integer|min:0',
            'remark' => 'nullable|string|max:1024',
            'status' => 'required|integer|min:0|max:4',
        ]);

注意一下这个用法:

'email' => ['required', 'email', Rule::unique('customer')->ignore(request('id'))->where(function ($query) {
                $query->whereNotIn('status', [4]);
            })],

这个意思是更新信息检测邮箱是否重复的时候,排除自己,并且排除状态为4的所有用户,我这里,状态为4的用户是删除的状态。如果这个邮箱是被删除的用户所使用,那么,也不检验重复性。

参考资料:https://laravel.com/docs/5.5/validation

文件位置:
D:\phpStudy\WWW\BCCKidAdmin\vendor\laravel\framework\src\Illuminate\Validation\Rules\DatabaseRule.php

关于各种的的验证:
D:\phpStudy\WWW\BCCKidAdmin\vendor\laravel\framework\src\Illuminate\Validation\Concerns\ValidatesAttributes.php
D:\phpStudy\WWW\BCCKidAdmin\vendor\laravel\framework\src\Illuminate\Validation\Concerns\ReplacesAttributes.php

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Laravel 使用 Migration 来创建和管理数据库表,使得数据库的管理变得更加简单和高效。 以下是使用 Migration 在 Laravel 中创建数据库表的步骤: 1. 首先,在命令行中使用 `php artisan make:migration` 命令创建一个 Migration 文件,命令格式如下: ``` php artisan make:migration create_table_name --create=table_name ``` 其中,`create_table_name` 是 Migration 文件名,`table_name` 是要创建的数据库表名。 2. 接着,打开刚刚创建的 Migration 文件,可以看到该文件包含了两个函数:`up()` 和 `down()`。 `up()` 函数用于定义创建数据库表的操作,`down()` 函数用于定义回滚操作。 3. 在 `up()` 函数中,使用 Laravel 提供的 Schema 构建器来定义数据库表的结构,例如: ``` public function up() { Schema::create('users', function (Blueprint $table) { $table->bigIncrements('id'); $table->string('name'); $table->string('email')->unique(); $table->string('password'); $table->timestamps(); }); } ``` 上述代码创建了一个名为 `users` 的数据库表,包含 `id`、`name`、`email`、`password` 和 `timestamps` 等字段。 4. 最后,在命令行中使用 `php artisan migrate` 命令将 Migration 文件中定义的数据库表结构应用到数据库中,命令格式如下: ``` php artisan migrate ``` 执行成功后,可以在数据库中看到新创建的 `users` 数据库表。 以上就是使用 Migration 在 Laravel 中创建数据库表的步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SHUIPING_YANG

你的鼓励是我创作的最大动力。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值