Home  >  Q&A  >  body text

php - laravel怎么实现多条件模糊查询,而且前端选择查询的选项可以为空!

laravel怎么实现多条件模糊查询,而且前端选择查询的选项可以为空!例如我这里有个商品表,然后搜索的选项有商品名称商品价格商品产地和商品上下架,这些查询条件可以全不为空,但是也所以为空,例如我查找价格为100块已经上架的商品,其他两个搜索选项为空,有或者我只查询上架的商品,其他选项为空!

伊谢尔伦伊谢尔伦2773 days ago423

reply all(2)I'll reply

  • 阿神

    阿神2017-04-10 17:53:30

    $handle = DB::table('table_name');
    
    // 如果条件1为真的时候
    $keywords1 && $handle->where('field_name','like','%' . $keywords1 . '%');
    // 如果条件2为真的时候
    $keywords2 && $handle->where('field_name','like','%' . $keywords2 . '%');
    // 如果条件3为真的时候
    ...
    
    
    // 获取数据
    $handle->get();
    
    

    如果是ORM的话:

    $handle = new Model();
    
     // 如果条件1为真的时候
    $keywords1 && $handle->where('field_name','like','%' . $keywords1 . '%');
    // 如果条件2为真的时候
    $keywords2 && $handle->where('field_name','like','%' . $keywords2 . '%');
    // 如果条件3为真的时候
    ...
    
    一样的

    reply
    0
  • PHP中文网

    PHP中文网2017-04-10 17:53:30

    //画蛇添足下
    $handle = \DB::table('table_name');
    $where = '1=1 ';
    if($condition1) {
      $where.= ' and field_name like "%' . $keywords1 . '%"';
    } elseif($condition2) {
      $where.= ' and field_name like "%' . $keywords2 . '%"';
    }
    $res = $handle->whereRaw($where)->get();
    

    reply
    0
  • Cancelreply