dongzhi6927 2017-11-27 15:53
浏览 18

仅当兄弟字段相同时,Laravel唯一值验证

Could someone please help to understand how to create store method validation in Laravel for the table with the current structure.

Schema::create('product_areas', function (Blueprint $table) {
    $table->increments('id');
    $table->integer('area_id')->unsigned();
    $table->integer('product_id')->unsigned();
});

The area_id field must be unique only when it has the same product_id within the same model.

This should be possible:

['id' => 1, 'area_id' => 1, 'product_id' => 1]
['id' => 2, 'area_id'=> 1, 'product_id' => 2]

Where this should throw an error:

['id' => 1, 'area_id' => 1, 'product_id' => 1]
['id' => 2, 'area_id'=> 1, 'product_id' => 1]

I have read the documentation but have not found similar scenario. I have very little idea of how this could be implemented.

Thank you all in advance.

  • 写回答

2条回答 默认 最新

  • dongshou7903 2017-11-27 16:08
    关注

    You can conditionally add a validation rule:

    $v = Validator::make($data, [
        'area_id' => 'required|integer',
        'product_id' => 'required|integer',
    ]);
    
    $v->sometimes('area_id', 'unique:product_areas', function ($input) {
        $products = \App\Product::where('id', $input->product_id)->count();
        return $products > 0;
    });
    

    The above logic will only apply the rule for area_id when the product_id returns at least one entry from the database. Here's the relevant documentation. You can also add a new validation rule, but I think the above may suffice in your case.

    评论

报告相同问题?

悬赏问题

  • ¥20 java在应用程序里获取不到扬声器设备
  • ¥15 echarts动画效果的问题,请帮我添加一个动画。不要机器人回答。
  • ¥60 许可证msc licensing软件报错显示已有相同版本软件,但是下一步显示无法读取日志目录。
  • ¥15 Attention is all you need 的代码运行
  • ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗
  • ¥15 使用esm_msa1_t12_100M_UR50S蛋白质语言模型进行零样本预测时,终端显示出了sequence handled的进度条,但是并不出结果就自动终止回到命令提示行了是怎么回事:
  • ¥15 前置放大电路与功率放大电路相连放大倍数出现问题
  • ¥30 关于<main>标签页面跳转的问题
  • ¥80 部署运行web自动化项目
  • ¥15 腾讯云如何建立同一个项目中物模型之间的联系