本人在实际开发中,根据产品经理需求,在iwebshop框架原有的后台订单筛选功能里增加商户名称模糊筛选!


开发思路:首先要明白筛选的数据在数据库中的位置,对要筛选的字段进行模糊查询!


开发主要注意:因为iwebshop后台订单筛选功能是写在封装好的一个类下面 order/order_class.php里面,所以sql查询后的遍历和sql本身的条件,一定要注意书写正确!


实际开发书写代码思路讲解:

if(isset($search['name']) && isset($search['keywords']))
{
   $name = IFilter::act($search['name'], 'string');
   $keywords = IFilter::act($search['keywords'], 'string');
   if ($name && $keywords)
   {
      switch ($name)
      {
         case "seller_name":
         {
          //执行查询订单管理商户名称
          $sellerObj = new IQuery('seller');
          $sellerObj->where="true_name like '%".$keywords."%'";
          $sellerRow =$sellerObj->find();
          $sellerArray =[];
          //遍历开始
            foreach ($sellerRow as $key=>$val){
               $sellerArray[] = $val['id'];
            }
           //因为涉及到单个模糊查询和多个模糊条件
            if(is_array($sellerArray)){
               $where .= $sellerRow ?" and o.seller_id in (".join(',',$sellerArray).")":"and null";
            }else{
               $where .= $sellerRow ?" and o.seller_id = ".$sellerArray[0]:"and null";
            }
         }
         break;

         default:
            $where .= " and o.".$name." = '".$keywords."'";
         break;
      }
   }
}