ThinkPHP框架,按分类,计算商品价格区间,来完成价格搜索

 //取出分类下的筛选属性
	    $cateId=I('get.cid');
	    /********计算这个分类下商品的七个价格区间的范围******/
	    $goodsModel = D("Goods");
	    $goodsPriceData=$goodsModel->field('MIN(shop_price) minprice,MAX(shop_price) maxprice,GROUP_CONCAT(shop_price) as priceStr')
	    ->where(array(
	        'cat_id'=>array('eq',$cateId),
	        'is_delete'=>array('eq',0),
	        'is_on_sale'=>array('eq',1),
	    ))->find();
	    
	    //算法:计算商品价格的七个区间
	     $priceNumber=7;
	    $sprice=ceil(($goodsPriceData['maxprice']-$goodsPriceData['minprice'])/$priceNumber);
	    $firsetPrice = $goodsPriceData['minprice'];
	    //接收七个区间的价格范围
	    $_priceNumber=array();
	    for($i=0;$i<$priceNumber;$i++){
	        if($i<($priceNumber-1))
	        $_priceNumber[]=(floor($firsetPrice/10)*10).'-'.(floor(($firsetPrice+$sprice)/10)*10-1);
	        else
	        $_priceNumber[]=(floor($firsetPrice/10)*10).'-'. ceil($goodsPriceData['maxprice']/10)*10;
	        
	        $firsetPrice+=$sprice;
	    }
	    //把从商品中取出来的价格字符串转化成数组后,
	    $goodsPrice=explode(',',$goodsPriceData['priceStr']);
	    sort($goodsPrice);
	    //在价格区间中做比对,如果区间中有商品保存价格区间,否则删除
	    foreach($_priceNumber as $k => $v){
	         $a = explode('-', $v);
	        $start=$a[0];
	        $end =$a[1];
	        $panduan=array();
	        foreach($goodsPrice as $k1 => $v1){
	            $v1=floor($v1);
	               //价格在此区间,把该价格保存在数组中
	            if($v1>=$start && $v1<=$end)
	                $panduan[]=$v1;
	            
	        }
	       //如果取出的商品没有在此价格区间的,删除该区间范围
	       if(empty($panduan))
	           unset($_priceNumber[$k]);
	       
	    }

  

转载于:https://www.cnblogs.com/kevinggk/p/7131628.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值