关于本站
“最难不过坚持”
本人承接扒站仿站,php网站维护,病毒查杀,网站编辑,网站改版,html制作
有需要网站维护,改版,病毒查杀,网站编辑,网站备案,html制作等相关的工作可以联系我。
本人有多年相关工作经验,也可提供免费咨询,交个朋友。
有需要探讨问题的朋友,也可以加我微信,共同探讨!
微信:15011482830 QQ:408917339
2712
39
分类目录
最新评论
- https://jueru.net/
-
评 留言
- :weixiao:
-
评 留言
- :shuijiao: :weiqu: :zhenbang: :leng:
-
评 留言
- :yiwen: :yiwen: :yiwen: :yiwen:
-
评 EasySass: could not generate CSS file. See Output panel for details.
- 这个业务逻辑多少都有点奇怪了,阅读浏览次数增值在新闻详情页的控制器方法里setInc,这怎么还写进模型事件里了。如果非要用onAfterRead也可以,把新闻文章的内容单独分出来一个news_content表,然后把它和news做关联,然后给news_content表的onAfterRead事件做增值处理,这样点进新闻页内查询到文章内容时才会触发它。
-
评 TP6模型事件-查询后onAfterRead不好用
文章标签更多
public function getTree(){
$artTree = cache('artTree');
if(!$artTree){
$data = Db::name('article_cats')->field('catName,catId,parentId')->where('dataFlag=1 and isShow=1')->cache(true)->select();
$artTree = $this->_getTree($data, 0);
cache('artTree',$artTree,86400);
}
return $artTree;
}
public function _getTree($data,$parentId){
$tree = [];
foreach($data as $k=>$v){
if($v['parentId']==$parentId){
// 再找其下级分类
$v['children'] = $this->_getTree($data,$v['catId']);
$tree[] = $v;
}
}
return $tree;
}
以上方法实现了三级分类,但是当分类多的时候,会很卡。
6000个分类,差不多要30秒,甚至php会返回error。
优化上述代码:
上述代码其实是查询到第四级分类的,即便没有四级分类,它也会遍历一次数组,查询每个三级分类下是否有四级分类。
我们明知道没有四级分类,可以加一个递归深度$deep,超过3级分类就不遍历了
6000个分类大概要10秒,省了很多时间
/**
* 列表
*/
public function listQuery(){
$rs = cache('GOODS_CAT');
if(!$rs){
$data = $this->field('catId,catTitle,parentId')->select();
$rs = $this->getTree($data, 0,1);
cache('GOODS_CAT',$rs,86400);
}
return $rs;
}
/**
* 组装三级分类
* $deep 分类深度
*/
public function getTree($data,$parentId,$deep){
$tree = [];
$deep++;
foreach($data as $k=>$v){
if($v['parentId']==$parentId){
// 再找其下级分类
if($deep <= 3){
$v['children'] = $this->getTree($data,$v['catId'],$deep);
}
$tree[] = $v;
}
}
return $tree;
}
然后把查询结果存入缓存,这样除了第一次花费时间,后面就快了
赏
相关推荐
Non-static method think\Config::get() should not be called statically
原来是这样use think\Config;
改成这样use think\facade\Config;
下面是官方手册的解释
配置获取
要使用Config类,首先需要在你的类文件中引入
use think\facade\Config;
或者(因为系统做了类库别名,其实就是调用think\facade\Config)
u...
ThinkPHP5 order多条件排序
总结如下:
//单一条件排序
$user = $this->where(['parentId'=>0)->field('userId,userName,userSort,isShow')->order('userSort', 'asc')->select();
//多个条件排序,可以多加一个order...
评论加载中...