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

Posted kevin

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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]);
	       
	    }

  

以上是关于ThinkPHP框架,按分类,计算商品价格区间,来完成价格搜索的主要内容,如果未能解决你的问题,请参考以下文章

mysql 查询时 按照某个字段计算后的值 排序?

thinkphp 对循环输出的数据进行求和计算

ThinkPHP(添加,修改,删除)

PHP.32-TP框架商城应用实例-后台10-商品分类-需求分析创建无限级商品分类,递归

PHP.36-TP框架商城应用实例-后台14-商品管理-商品扩展分类的删除修改

微信小程序商城构建全栈应用 Thinkphp5