PHP.51-TP框架商城应用实例-前台3-楼层推荐、TP框架雪崩问题
楼层推荐
效果图

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框架雪崩问题的更多相关文章
- PHP.50-TP框架商城应用实例-前台2-商品推荐
商品推荐 {抢购,新品,精品,热卖}效果如下 1.在商品表增加促销价格与促销起始时间和结束时间三个字段,字段推荐楼层与排序在后面用到 注意:在增加datetime类型字段时,要添加默认值{datet ...
- PHP.49-TP框架商城应用实例-前台1-公共布局、制作首页
公共布局包括 1.页头.页脚{layout} 正文:{__COMMENT__} 导入:<layout name="layout"> 2.商品导航{nav.html} = ...
- PHP.52-TP框架商城应用实例-前台4-商品详情页-面包屑导航、AJAX浏览历史
面包屑导航 思路:根据商品的主分类向上取出所有上级分类即可 1.在分类模型中增加取出所有上级分类的方法 /********** [面包屑导航]取出一个分类所有上级分类 **********/ pub ...
- PHP.24-TP框架商城应用实例-后台1-添加商品功能、钩子函数、在线编辑器、过滤XSS、上传图片并生成缩略图
添加商品功能 1.创建商品控制器[C] /www.test.com/shop/Admin/Controller/GoodsController.class.php <?php namespace ...
- PHP.28-TP框架商城应用实例-后台5-多表操作-商品表与品牌表
表与表之间的关系:1:1 1:多 多:多 功能需求决定表关系 此处的表关系为:品牌表:商品表=1:多 1.首先在表结构上关联,在多的表(商品表)添加一个字段,关联一的表(品牌表)的ID(主键) 添加字 ...
- PHP.27-TP框架商城应用实例-后台4-使用Gii生成品牌表的代码
Gii安装[GII适用于商城项目] 将Gii文件夹复到application 是,访问http://xx.com/index.php/gii Gii规则[Gii使用规则与建表规则密切相关] 1.建表字 ...
- PHP.48-TP框架商城应用实例-后台23-权限管理-权限验证
权限验证 1.登录控制器 2.通过tp验证码类生成验证码图片 3.在管理员模型增加登录验证规则 4.后台中所有的控制器必须先登录才能访问 思路:在访问任何一个控制器之前都判断一个session即可,= ...
- PHP.43-TP框架商城应用实例-后台18-商品属性3-库存量管理
库存量管理 思想:为商品的每个多选属性设置库存量!!要把多选属性排列组合分别指定库存量!! 效果如下:[由商品已经添加的属性决定] 1.建表goods_number{goods_id,goods_nu ...
- PHP.38-TP框架商城应用实例-后台14-商品管理-商品扩展分类的删除、修改
商品分类删除 1.删除商品时,根据商品id删除扩展分类表数据 商品扩展分类修改 1.在控制器GoodsController.class.php/edit()中根据商品id取出对应的所有扩展分类 2.在 ...
随机推荐
- 记一次挖掘115网盘反射型xss,08xss的储存型xss
记一次对115分站简单绕过过滤继续实现xss,08xss平台也中枪!! 115反射型xss url:http://115.qiye.115.com/disk/?ac=select_public_fil ...
- 【JAVA EE企业级开发四步走完全攻略】
本文是J2EE企业级开发四步走完全攻略索引,因内容比较广泛,涉及整个JAVA EE开发相关知识,这是一个长期的计划,单个发blog比较零散,所以整理此索引,决定以后每发一季JAVA EE blog后会 ...
- Ubuntu14.04安装PowerDNS踩坑实录
公司要使用PowerDNS,作为内网域名解析的工具.让我和另一组的同事学一下如何配置及调优.所以先找了两台服务器试着安装一下.这一装就是一个礼拜,经历了大大小小的坑,记下来以后可能需要参考.安装过程如 ...
- 【剑指offer】数组中的逆序对
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/mmc_maodun/article/details/27520535 转载请注明出处:http:// ...
- BZOJ2882:工艺(SAM)
Description 小敏和小燕是一对好朋友. 他们正在玩一种神奇的游戏,叫Minecraft. 他们现在要做一个由方块构成的长条工艺品.但是方块现在是乱的,而且由于机器的要求,他们只能做到把这个工 ...
- 「hihocoder1413 Rikka with String」
题目 哈哈哈哈哈哈哈哈哈哈我还没自闭 好像前后调了两天了 哈哈哈哈哈哈哈哈哈哈我还没自闭 这道题就是给定一个小写字母串,回答分别把每个位置上的字符替换为\(#\)后的本质不同的子串数 首先就是跨过这个 ...
- ThinkPHP中前台输出变量
1. foreach <foreach name="list" item="vo" > {$key}|{$vo.id}:{$vo.name} & ...
- Sublime Text 3中关闭记住上次打开的文件
使用UltraEdit的时候,每次安装后就得修改一堆配置,其中一项便是关闭“打开上一次未关闭的文件”,Sublime Text 2也有这么一个默认的功能,在实际使用中,这种方式确实可以较快速的访问文件 ...
- 最简单的Servlet继承HttpServlet查询数据库登录验证
<%-- Created by IntelliJ IDEA. User: yunqing Date: 2017-12-06 Time: 9:11 To change this template ...
- Spring MVC 使用tomcat中配置的数据源
Spring MVC 使用tomcat中配置的数据源 配置tomcat数据源 打开tomcat目录下的conf目录,编辑sever.xml目录.在<GlobalNamingResources&g ...