开发者

Sorting a list by references

开发者 https://www.devze.com 2022-12-14 10:39 出处:网络
I have a table containing (essentially) three columns - id, name, ref_id. I would like to create an indented list where the columns wit开发者_如何学Ch ref_id would be indented below the column with t

I have a table containing (essentially) three columns - id, name, ref_id.

I would like to create an indented list where the columns wit开发者_如何学Ch ref_id would be indented below the column with the corresponding id, for example:

Name      | ID | Ref ID
about       1    0
story       2    1
history     3    1
contact     4    0
help        5    0
map         6    4
directions  7    4

Would ideally create something like this:

about
- story
- history
contact
- map
- directions
help

What would be ideal is one MySQL query that would return the full list as above, if not something that would create it with the least amount of SQL calls and cpu usage. The only way I can think of doing it is incredibly wasteful and I am sure there is a better way.

Thanks in advance!


--MySQL 5.1 happiness
SELECT
   CASE WHEN tp.Level = 1 THEN tp.Parent
   ELSE CONCAT( '- ', tp.Name)
   END AS result
FROM (

    SELECT
     t.name,
     CASE
              WHEN t.ref_id = 0 THEN t.name
              ELSE t2.name
       END AS Parent,
       CASE
              WHEN t.ref_id = 0 THEN 1
              ELSE 2
       END AS Level
    FROM question_1900097 t
    LEFT JOIN question_1900097 t2 ON t.ref_id = t2.id

    ) AS tp
ORDER BY tp.Parent, tp.Name;


The PHP version

$in = array(
    array('about',1,0),
    array('story',2,1),
    array('history',3,1),
    array('contact',4,0),
    array('help',5,0),
    array('map',6,4),
    array('directions',7,4)
);
foreach ($in as $k => $v) {
    if ($v[2] === 0) { $out[$v[1]][0] = $v; };
    if ($v[2] > 0) { $out[$v[2]][1][] = $v;};
}
foreach ($out as $k => $v) {
    echo $v[0][0] . "\n";
    if (isset($v[1])) {
    foreach ($v[1] as $sk => $sv) {
        echo " - " .$sv[0] . "\n";
    }
    }
}
0

精彩评论

暂无评论...
验证码 换一张
取 消