根据一个分类id 获取这个分类底下所有子分类的商…

2018-06-17 18:58:14来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

/**
 * 检测该分类下所有子分类,并输出ID(包括自己)
 * 数据库字段 catid pid
 */
function getChildrenIds ($sort_id){
	include_once APPPATH.'/libraries/db.php';
	$db = new Db();
	$ids = $sort_id;
	$sql = "SELECT catid,pid FROM jy_category WHERE pid =".$sort_id;
	$result = $db->select($sql);

	if ($result){
		foreach ($result as $key=>$val){
			$ids .= ','.$val['catid'].",";
			$ids .= getChildrenIds ($val['catid']);
		}
	}
	
	$idsArr = explode(",",$ids);
	$idsArr = array_unique($idsArr);
	$ids = implode(",",$idsArr);
	return $ids;
}

  

/**
 * 检测该分类下所有子分类,并输出ID(不包括自己)
 * 数据库字段 catid pid
 */
function getChildrenIds ($sort_id)
   {
       $db = $this->loadDB();
       $ids = '';
       $sql = "SELECT * FROM t_dept WHERE `parent_id` = '{$sort_id}'";
       $query = $db->query($sql);
       $result = $query->result_array();
 
       if ($result)
       {
           foreach ($result as $key=>$val)
           {
               $ids .= ','.$val['id'];
               $ids .= $this->getChildrenIds ($val['id']);
           }
       }
       return $ids;
}

  上面的查询数据库次数太多了 然后下面这个就好一点,三级分类最多查询三次

	/**
	 * 检测该分类下所有子分类,并输出ID
	 */
	public function getChildrenIds ($pid,$sort_id){
		$aPid = array();
		if(!is_array($pid)){
			$aPid[]=$pid;
		}else{
			$aPid = $pid;
		}
		
		$sql = "SELECT catid,pid FROM jy_category WHERE pid in({$sort_id})";
		$result =$this->db->select($sql);

		$aSort = array();
		$aUnion = array();
		if ($result){
			foreach ($result as $key=>$val){
				$aSort[] = $val['catid'];
			}

			$aUnion = $this->getChildrenIds($aSort,implode(",",$aSort));
		}
		
		
		return array_merge($aPid,$aUnion);
	}

  

  

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:[工具] Firemonkey Style 调色工具(可另存 Style 文件)

下一篇:delphi7 写的一个验证btcdice网站结果的程序