欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

PHP递归写入MySQL实现无限级分类数据操作示例

程序员文章站 2022-09-04 09:33:19
本文实例讲述了php递归写入mysql实现无限级分类数据操作。分享给大家供大家参考,具体如下: php递归写入mysql无限级分类数据,表结构: create...

本文实例讲述了php递归写入mysql实现无限级分类数据操作。分享给大家供大家参考,具体如下:

php递归写入mysql无限级分类数据,表结构:

create table `kepler_goods_category` (
 `id` int unsigned not null primary key auto_increment,
 `parentid` int unsigned not null default 0 comment '父级分类id',
 `name` varchar(255) not null default '' comment '分类名称',
 `kepler_fid` int unsigned not null default 0 comment '对应开普勒分类id',
 `create_time` timestamp not null default current_timestamp on update current_timestamp
) engine=innodb default charset=utf8;

递归方法写入代码:

static public function addcategoryfromkepler($fid, $parentid = 0){
  $category_list = kepler::querygoodscategorylist($fid); // 获取数据
  $category_list = $category_list['jd_kepler_item_querycategoriesbyfid_response'];
  if($category_list['total'] > 0){
    foreach ($category_list['categories'] as $key => $value) {
      $parentid_sub = keplercategory::addcategory($value['name'], $value['id'], $parentid); // 插入数据库,得到父id
      self::addcategoryfromkepler($value['id'], $parentid_sub); // 递归
    }
  }
  return true;
}

调用代码:

keplercategory::addcategoryfromkepler(0);

递归方法读取代码:

static public function getcategoryformattokepler($parentid, $format_data = array(), $parent_prefix = '', $current_prefix = ''){
  $category_list = self::getcategorybyparentid($parentid); // 根据父id获取
  if(!empty($category_list)){
    foreach ($category_list as $key => $value) {
      $format_data = self::getcategoryformattokepler($value['id'], $format_data, $parent_prefix . ',' . $current_prefix, $value['kepler_fid']);
    }
  }else{
    $format_data[] = trim($parent_prefix . ',' . $current_prefix, ',');
  }
  return $format_data;
}

调用代码:

$category_list = keplercategory::getcategoryformattokepler(0);

更多关于php相关内容感兴趣的读者可查看本站专题:《php+mysql数据库操作入门教程》、《php+mysqli数据库程序设计技巧总结》、《php面向对象程序设计入门教程》、《php数组(array)操作技巧大全》、《php字符串(string)用法总结》及《php常见数据库操作技巧汇总

希望本文所述对大家php程序设计有所帮助。