SELECT and list children and parent

后端 未结 2 1281
梦谈多话
梦谈多话 2021-01-24 03:12

I need a SQL query for the following COMPLEX task...

I need to to select from a column named parent_id. If a row has 0 for parent_id it means t

2条回答
  •  执念已碎
    2021-01-24 03:37

    Try this fiddle http://sqlfiddle.com/#!2/0a9c5/16, sql code below

    SELECT c.rule_id, c.rule_title, GROUP_CONCAT(r.rule_title)
    FROM RULES_TABLE AS c
    LEFT JOIN RULES_TABLE AS r
        ON r.parent_id = c.rule_id
    WHERE c.parent_id IS NULL AND c.public = 1
    GROUP BY c.rule_id
    ORDER BY c.cat_position, c.rule_position;
    

    left out php-ization of code on purpose to maintain syntax highlighting, which seems not to work anyway

    If you exceed maximum allowed group_concat size you can either increase it or use the following version, and do a bit more processing in php:

    SELECT c.rule_id, c.rule_title, r.rule_title as r_rule_title
    FROM RULES_TABLE AS c
    LEFT JOIN RULES_TABLE AS r
        ON r.parent_id = c.rule_id
    WHERE c.parent_id IS NULL AND c.public = 1
    ORDER BY c.cat_position, c.rule_position;
    

    and in php, skeleton code provided only, fill in with the actual values, assuming you use pdo and your pdostatement var is named $query:

    $old_rule_id = null;
    $rrt = array(); // will contain all r.rule_titles for a give c.rule_id
    while( ($i = $query->fetch(PDO::FETCH_OBJ)) !== false ) {
        if( $old_rule_id != $i->rule_id ) {
            if( count($rrt) ) {
                echo ... all the data for previous rule from $rrt ...
                echo ... end of previous element ...
                $rrt = array(); // empty it to collect new data
            }
            echo ... start of current element use data from $i->rule_id and $i->rule_title ...
            $old_rule_id = $rule_id;
        }
        $rrt[] = $i->r_rule_title;
    }
    // the following is the same if from inside the while, minus reinitialization of $rrt;
    if( count($rrt) ) {
        echo ... all the data for previous rule from $rrt ...
        echo ... end of previous element ...
    }
    

    replace stuff between ... with valid code

提交回复
热议问题