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.在 ...
随机推荐
- nohup命令、setsid命令、Daemon(守护进程)简要梳理
nohup命令 当用户注销(logout)或者网络断开时,终端会收到 HUP(hangup)信号从而关闭其所有子进程.因此,我们的解决办法就有两种途径:要么让进程忽略 HUP 信号,要么让进程运行在新 ...
- jsp和servlet的问题收集.... 答案有部分是自己理解的,可能有点差异
如何创建一个动态工程? File ----> New ---->other ---->Web ---->Dynamic Web Project 选择动态WEB 项目工程 W ...
- PhoneGap Geolocation 获取地理位置 api
一. PhoneGap Geolocation 对象介绍 1.使应用程序可以访问地理位置信息.geolocation 对象提供了对设备 GPS 传感器的访问.Geolocation 提供设备的位置信息 ...
- (二)给Centos配置网络以及使用xshell远程连接Centos
好吧,我对网络协议以及ip配置知识的匮乏,让我在这里折腾了将近一天才搞定.可以说基本上网上遇到的问题我都遇到了.在这里,记下正确的步骤来给Centos配置网络.希望以后少走弯路. 首先我要说明的是,我 ...
- 交叉熵Cross-Entropy
1.交叉熵:用来描述通信中将一个概率分布的最优编码用到另一个概率分布的平均比特数 公式: 2.交叉熵是不对称的 3.交叉熵的作用是表达两个概率分布的差异性 设概率分布p(x)和q(x),两个概率分布差 ...
- PHP----练习------球队列表
题目:页面上有一个ul球队列表当鼠标移动到某个li上的时候改行背景颜色变红,当点击某个li的时候,让该li之前的所有li背景色变黄,之后的所有li背景色变蓝.自己不变色. <!DOCTYPE h ...
- Codeforces Round #527 (Div. 3) F. Tree with Maximum Cost 【DFS换根 || 树形dp】
传送门:http://codeforces.com/contest/1092/problem/F F. Tree with Maximum Cost time limit per test 2 sec ...
- [19/03/31-星期日] IO技术_四大抽象类_字符流( 字符输入流 Reader、 字符输出流 Writer )(含字符缓冲类)
一.概念 Reader Reader用于读取的字符流抽象类,数据单位为字符. int read(): 读取一个字符的数据,并将字符的值作为int类型返回(0-65535之间的一个值,即Unicode ...
- css3的代替图片的三角形
1.小三角形(与边框结合,不兼容IE8) .callout{ position: relative; width: 100px; height: 100px; background: #fce6ed; ...
- Linux学习总结(十三)文本编辑器 vim
vim是vi的升级版,会根据文本属性带色彩显示,具体用法如下: 一般模式 : 1.光标定位: 左右移动一个字符, h l上下移动一个字符, k j左右下上 ,左右在两边,下上在中间这样记光标定位行首 ...