在php codeigniter中的父项下显示子记录

时间:2018-11-08 08:44:51

标签: php html5 codeigniter

我有一个Tbl,其中包含以下字段。我只能显示第一级并显示正常。但是我想在各自的父级下获取每个父级显示的子级详细信息。请在“高级”中帮助我。

id pid  name
1   0   proc
2   0   prod
3   0   dash
4   3   dash-prod

这是我的模式代码

function get_all_access_list(){
    $db = $this->connect_db();
    $output =array();
    $db->select('access_module_id,access_parent_module,access_module_name');
    $db->from('access_permissions');
    $db->where('access_parent_module =',0);
    $query = $db->get();
    if( $query->num_rows() > 0 ){
        $output = $query->result();
    }
    return $output;
}

这在查看代码中

<?php 
if( !empty($access_list) ){
    foreach( $access_list AS $acces_name ){ ?>
        <input type="checkbox" name="access_name[]" id="acces_name" value="<?php echo $acces_name->access_module_id; ?>">
        <span class="label-text fa-lg"><?php echo $acces_name->access_module_name;?></span>
<?php 
    }
}
?>

1 个答案:

答案 0 :(得分:0)

就MySQL查询而言,我们可以定义一个自定义的排序参数。如果pid的值为0,我们可以简单地使用id的值进行排序;否则为pid值。这是因为其他级别的pid值与父级别的id相同。

我们还将使用多级Order By,第二级排序使用id

您可以执行以下操作:

SELECT 
  t.id, 
  t.name 
FROM 
  your_table AS t 
ORDER BY 
  CASE WHEN t.pid = 0 THEN t.id 
       ELSE t.pid 
  END
  , t.id