楼层推荐

效果图

1、增加表字段

  商品表

   分类表

2、修改商品模型和分类模型接收字段is_floor

3、修改商品和分类相关的表单

4、后台制作推荐方法

  4.1在分类模型中增加获取前台楼层数据的方法

/****** 获取前台首页楼层中的数据 ***********/
public function floorData()
{
$floorData = S('floorData');
if($floorData)
return $floorData;
else
{
// 先取出推荐到楼层的顶级分类
$ret = $this->where(array(
'parent_id' => array('eq', 0),
'is_floor' => array('eq', '是')
))->select();
//var_dump($ret);die;
$goodsModel = D('Admin/Goods');
// 循环每个楼层取出楼层中的数据
foreach ($ret as $k => $v)
{
/*********** 这个楼层中的品牌数据 *************/
// 先取出这个楼层下所有的商品ID
$goodsId = $goodsModel->getGoodsIdByCatId($v['id']); // 再取出这些商品所用到的品牌
$ret[$k]['brand'] = $goodsModel->alias('a')
->join('LEFT JOIN __BRAND__ b ON a.brand_id=b.id')
->field('DISTINCT brand_id,b.brand_name,b.logo')
->where(array(
'a.id' => array('in', $goodsId),
'a.brand_id' => array('neq', 0),
))->limit(9)->select();
//var_dump($ret[0]['brand']);die; /**** 取出未推荐的二级分类并保存到这个顶级分类的subCat字段中 ****/
$ret[$k]['subCat'] = $this->where(array(
'parent_id' => array('eq', $v['id']),
'is_floor' => array('eq', '否'),
))->select();
//var_dump($ret[0]['subCat']);die;
/****** 取出推荐的二级分类并保存到这个顶级分类的subCat字段中 *******/
$ret[$k]['recSubCat'] = $this->where(array(
'parent_id' => array('eq', $v['id']),
'is_floor' => array('eq', '是'),
))->select();
//var_dump($ret[0]['recSubCat']);die;
/***** 循环每个推荐的二级分类取出分类下的8件被推荐到楼层的商品 ****/
foreach ($ret[$k]['recSubCat'] as $k1 => &$v1)
{
//取出这个分类下所有商品的ID并返回一维数组
$gid = $goodsModel->getGoodsIdByCatId($v1['id']);
$gids = implode(",", $gid);
//var_dump($gids);die;
// 再根据商品ID取出商品的详细信息
$v1['goods'] = $goodsModel->field('id,mid_logo,goods_name,shop_price')
->where(array(
'is_on_sale' => array('eq', '1'),
'is_floor' => array('eq', '是'),
'id' => array('in', $gids),
))->order('sort_num ASC')->limit(8)->select();
//var_dump($v1['goods']);die;
}
}
S('floorData', $ret, 5);
return $ret;
}
}

       4.2在IndexController.class.php控制器中取出数据

   4.3在首页中循环输出   ==> 包括品牌信息

 5、为前台页面生成缓存

扩展:解决TP框架雪崩问题

生成静态缓存的雪崩问题:如果网站的并发量在100【每秒有100个刷新】,在缓存页面失效的一瞬间,100个并发同时进入到后端数据库有可能让数据库崩溃。

解决方法:修改TP底层源码,在生成静态缓存页时加锁,在缓存失效时只让一个客户端进入控制器      ==>PHP文件锁

PHP.51-TP框架商城应用实例-前台3-楼层推荐、TP框架雪崩问题的更多相关文章

  1. PHP.50-TP框架商城应用实例-前台2-商品推荐

    商品推荐 {抢购,新品,精品,热卖}效果如下 1.在商品表增加促销价格与促销起始时间和结束时间三个字段,字段推荐楼层与排序在后面用到  注意:在增加datetime类型字段时,要添加默认值{datet ...

  2. PHP.49-TP框架商城应用实例-前台1-公共布局、制作首页

    公共布局包括 1.页头.页脚{layout} 正文:{__COMMENT__} 导入:<layout name="layout"> 2.商品导航{nav.html} = ...

  3. PHP.52-TP框架商城应用实例-前台4-商品详情页-面包屑导航、AJAX浏览历史

    面包屑导航  思路:根据商品的主分类向上取出所有上级分类即可 1.在分类模型中增加取出所有上级分类的方法 /********** [面包屑导航]取出一个分类所有上级分类 **********/ pub ...

  4. PHP.24-TP框架商城应用实例-后台1-添加商品功能、钩子函数、在线编辑器、过滤XSS、上传图片并生成缩略图

    添加商品功能 1.创建商品控制器[C] /www.test.com/shop/Admin/Controller/GoodsController.class.php <?php namespace ...

  5. PHP.28-TP框架商城应用实例-后台5-多表操作-商品表与品牌表

    表与表之间的关系:1:1 1:多 多:多 功能需求决定表关系 此处的表关系为:品牌表:商品表=1:多 1.首先在表结构上关联,在多的表(商品表)添加一个字段,关联一的表(品牌表)的ID(主键) 添加字 ...

  6. PHP.27-TP框架商城应用实例-后台4-使用Gii生成品牌表的代码

    Gii安装[GII适用于商城项目] 将Gii文件夹复到application 是,访问http://xx.com/index.php/gii Gii规则[Gii使用规则与建表规则密切相关] 1.建表字 ...

  7. PHP.48-TP框架商城应用实例-后台23-权限管理-权限验证

    权限验证 1.登录控制器 2.通过tp验证码类生成验证码图片 3.在管理员模型增加登录验证规则 4.后台中所有的控制器必须先登录才能访问 思路:在访问任何一个控制器之前都判断一个session即可,= ...

  8. PHP.43-TP框架商城应用实例-后台18-商品属性3-库存量管理

    库存量管理 思想:为商品的每个多选属性设置库存量!!要把多选属性排列组合分别指定库存量!! 效果如下:[由商品已经添加的属性决定] 1.建表goods_number{goods_id,goods_nu ...

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

    商品分类删除 1.删除商品时,根据商品id删除扩展分类表数据 商品扩展分类修改 1.在控制器GoodsController.class.php/edit()中根据商品id取出对应的所有扩展分类 2.在 ...

随机推荐

  1. DB TABLE实践

    我的数据库设计实践(一)   兜兜转转,突然发现我现在已经是一个老司机了,一直写代码都很忙,没有把很多点点滴滴的记录下来,今天开始就开始一个系列,分析当年我接触或者我设计过的表结构,有好有坏,有欢喜也 ...

  2. Java关于日期时间的工具类

    import java.sql.Timestamp; import java.text.ParseException; import java.text.ParsePosition; import j ...

  3. spring的声明式的事物管理和编程事务管理的区别

    一.Spring对编程式事务的支持 Spring中的事务分为物理事务和逻辑事务: 物理事务:就是底层数据库提供的事务支持,如JDBC或JTA提供的事务: 逻辑事务:是Spring管理的事务,不同于物理 ...

  4. iOS - CocoaPods 和 Carthage 的比较

    CocoaPods 好处? 开发 iOS 项目不可避免地要使用第三方开源库,CocoaPods 的出现使得我们可以节省设置和更新第三方开源库的时间 在引入第三方库时它可以自动为我们完成各种各样的配置, ...

  5. functions and closures are reference types-函数和闭包是引用类型

    Closures Are Reference Types In the example above, incrementBySeven and incrementByTen are constants ...

  6. BZOJ4887:[TJOI2017]可乐(矩阵乘法)

    Description 加里敦星球的人们特别喜欢喝可乐.因而,他们的敌对星球研发出了一个可乐机器人,并且 放在了加里敦星球的1号城市上.这个可乐机器人有三种行为:停在原地,去下一个相邻的 城市,自爆. ...

  7. ASP.NET Core 程序发布到Linux(Centos7)爬坑实战

    前言 前阶段弄了个Linux系统想倒腾倒腾.NET Core,结果看了下网上的资料,大部分都是过期的,走了不少弯路,不过还好,今下午总算捣鼓出来了.Linux命令太多了,唉.血的教训:安装一定要看官网 ...

  8. table中实现数据上移下移效果

    html 由于vue+Element项目中的table,没有开放的上移下移的api,但是能对数据操作,故思路为数组中的一条数据,再重新添加一条数据,办法有点笨,但是好歹也是实现了,望有好的办法的,请留 ...

  9. C#XML格式字符串取节点数据

    XML格式的字符串: <xml><return_code><![CDATA[{0}]]></return_code><return_msg> ...

  10. spring加载属性(properties)文件

    一.注解方式加载 jdbc.driver=org.mariadb.jdbc.Driver jdbc.url=jdbc:mariadb://localhost:3306/kt jdbc.user=roo ...