dslijian2015 2017-08-14 12:17
浏览 10

cakePHP验证existsIn()for empty / Null字段,如何摆脱......?

I have 2 tables Orders and Products. In orders table has foreign key product_id. Sometimes it's not necessary that order must contain the product(order without any product id is allowed). In this scenario my existIn validation rule causing the problem to save data.

$rules->add($rules->existsIn(['product_id'], 'Products'));  //Validation in the model of Orders.

N.B. - Keep in mind that I have allowed product_id to be null in my DB.

  • 写回答

1条回答 默认 最新

  • dongmale0656 2017-08-14 14:24
    关注

    Edit: Per the comment by ndm existsIn checking for null or existing in should be the default functionality of existsIn if your column is nullable in the database. If its not working perhaps you are passing some kind of value accidentally or your column is not listed as nullable.

    You should also be able to override the exists in to allow for this or other conditions. Basically you will specify an exists in or it is a certain value. In this case null.

    Answer modified from How to build rule exist in or equal to a number in cakephp 3?

    $rules->add(
    function ($entity, $options) {
        $rule = new ExistsIn(['product_id'], 'Products');
        return $entity->product_id === NULL || $rule($entity, $options);
    },
        ['errorField' => 'product_id', 'message' => 'Product ID specified but does not exist']
    );
    
    评论

报告相同问题?

悬赏问题

  • ¥15 帮我写一个c++工程
  • ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
  • ¥15 关于smbclient 库的使用
  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教