您现在的位置是:网站首页> 编程资料编程资料
在TP5数据库中四个字段实现无限分类的示例_php实例_
2023-05-25
261人已围观
简介 在TP5数据库中四个字段实现无限分类的示例_php实例_
效果:

CREATE TABLE `NewTable` ( `id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT , `pid` int(10) UNSIGNED ZEROFILL NOT NULL , `name` varchar(30) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL , `path` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL , PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARACTER SET=utf8 COLLATE=utf8_general_ci AUTO_INCREMENT=53 CHECKSUM=0 ROW_FORMAT=DYNAMIC DELAY_KEY_WRITE=0 ;
Document 四个字段的无限分类
order('concat(path,"-",id)')->select(); #order('concat(path,"-",id)')自动排序 foreach ($data as &$cate) { $prefix=''; $i=count(explode("-", $cate['path'])); for($n=0;$n<=$i;$n++){ $prefix.="--"; } $cate['pre']=$prefix; } $this->assign('cates',$data); return $this->fetch(); } public function add(){ $db=Db::name('categroy'); if($_POST['pid']==0){ $_POST['path']=0; }else{ $_POST['path']=$db->where('id='.$_POST['pid'])->value('path')."-".$_POST['pid']; } $name=$_POST['name']; if($db->insert($_POST)){ $this->success('添加成功'); }else{ $this->error('添加失败'); } #原理:4个字段 /* ID PID NAME PATH 1 0 服装 0-1 2 0 游戏 0-2 3 1 男装 0-1-3 4 3 上衣 0-1-3-4 */ }} 还有一个没有写完的递归无限分类
public function user(){ $db=Db::name('categroy1'); // $data=$db->getTree(); $opt=$db->getOption($data); $this->assign('opt',$opt); $this->assign('cates',$data); return $this->fetch(); } public function doAdd(){ //执行添加数据 $db=Db::name('categroy1'); if($db->insert()){ $this->success('添加成功',url('index')); }else{ $this->error('添加失败',url('index')); } return $this->fetch(); }Model
where('pid='.$pid)->select(); foreach($data as &$cate){ #通过该分类的主键id查询该分类的子类 $cate['cates']=$this->getTree($cate['id']); } return $data; } #拼装属性结构 #通过一个数组组装option public function getOption($data){ static $i=0; for($n=0;$n<=$i*2;$n++){ $prefix.="-"; } foreach ($data as $cate) { $opt.=""; #判断该分类下是否包含子类,如果有子类,将数组传入接着拼装 if(!empty($case['cates'])){ $i++; $opt.=$this->getOption($case['cases']); }else{ $i=0; } return $opt; } } }以上这篇在TP5数据库中四个字段实现无限分类的示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
您可能感兴趣的文章:
相关内容
- PHP getID3类的使用方法学习笔记【附getID3源码下载】_php技巧_
- PHP使用JpGraph绘制折线图操作示例【附源码下载】_php技巧_
- tp5.1 实现setInc字段自动加1_php实例_
- php 比较获取两个数组相同和不同元素的例子(交集和差集)_php实例_
- thinkphp5 模型实例化获得数据对象的教程_php实例_
- 使用tp框架和SQL语句查询数据表中的某字段包含某值_php实例_
- tp5 sum某个字段相加得到总数的例子_php实例_
- 基于laravel belongsTo使用详解_php实例_
- 浅谈laravel 5.6 安装 windows上使用composer的安装过程_php实例_
- Laravel 框架返回状态拦截代码_php实例_
