php 商品价格区间表,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

if($i

$_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]);

}

原文:http://www.cnblogs.com/kevinggk/p/7131628.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值