开发者

Need help for a SQL query

开发者 https://www.devze.com 2023-02-22 23:40 出处:网络
This is my table structure: idid_parentid_originlevelname 1011PHP 2021Javascript 3031SMARTY 4041HTML 51 开发者_JS百科12Basic

This is my table structure:

id  id_parent   id_origin   level   name
1   0   1   1   PHP
2   0   2   1   Javascript
3   0   3   1   SMARTY
4   0   4   1   HTML
5   1 开发者_JS百科  1   2   Basic
6   1   1   2   Date & Math Function
8   2   2   2   DOM
9   5   1   3   Introduction
10  5   1   3   Session & Cookies
12  2   2   2   Introduction
13  4   4   2   Basic Structure
14  6   1   3   PHP Date Function
16  3   3   2   Basic Syntax
26  4   4   2   Table

I want result like below format

Myfinalstr
-----------
PHP
PHP->Basic
PHP->Basic->Introduction
PHP->Basic->Session & Cookies
PHP->Date & Match Function
PHP->Date & Match Function->PHP Date Function
Javascript
Javascript->DOM
Javascript->Introduction
SMARTY
SMARTY->Basic Syntax
HTML
HTML->Basic Structure
HTML->Table


The following isnt a complete solution but it will get you started:

Example stored procedure call

mysql> call chapter_hier(1);
+----+----------------------+-----------+----------------------+-------+
| id | category_name        | id_parent | parent_category_name | depth |
+----+----------------------+-----------+----------------------+-------+
|  1 | PHP                  |      NULL | NULL                 |     0 |
|  5 | Basic                |         1 | PHP                  |     1 |
|  6 | Date & Math Function |         1 | PHP                  |     1 |
|  9 | Introduction         |         5 | Basic                |     2 |
| 10 | Session & Cookies    |         5 | Basic                |     2 |
| 14 | PHP Date Function    |         6 | Date & Math Function |     2 |
+----+----------------------+-----------+----------------------+-------+
6 rows in set (0.00 sec)

$result = $conn->query(sprintf("call chapter_hier(%d)", 1));

Full script and test data

drop table if exists chapters;
create table chapters
(
id smallint unsigned not null primary key,
name varchar(255) not null,
id_parent smallint unsigned null,
key (id_parent)
)
engine = innodb;

insert into chapters (id, name, id_parent) values
(1,'PHP',null),
(2,'Javascript',null),
(3,'SMARTY',null),
(4,'HTML',null),
(5,'Basic',1),
(6,'Date & Math Function',1),
(8,'DOM',2),
(9,'Introduction',5),
(10,'Session & Cookies',5),
(12,'Introduction',2),
(13,'Basic Structure',4),
(14,'PHP Date Function',6),
(16,'Basic Syntax',3),
(26,'Table',4);


drop procedure if exists chapter_hier;
delimiter #

create procedure chapter_hier
(
in p_id smallint unsigned
)
begin

declare v_done tinyint unsigned default 0;
declare v_depth smallint unsigned default 0;

create temporary table hier(
 id_parent smallint unsigned, 
 id smallint unsigned, 
 depth smallint unsigned default 0
)engine = memory;

insert into hier select id_parent, id, v_depth from chapters where id = p_id;
create temporary table tmp engine=memory select * from hier;

/* http://dev.mysql.com/doc/refman/5.0/en/temporary-table-problems.html */

while not v_done do

    if exists( select 1 from chapters c
        inner join tmp on c.id_parent = tmp.id and tmp.depth = v_depth) then

        insert into hier select c.id_parent, c.id, v_depth + 1 from chapters c
            inner join tmp on c.id_parent = tmp.id and tmp.depth = v_depth;

        set v_depth = v_depth + 1;          

        truncate table tmp;
        insert into tmp select * from hier where depth = v_depth;

    else
        set v_done = 1;
    end if;

end while;

select 
 c.id,
 c.name as category_name,
 p.id as id_parent,
 p.name as parent_category_name,
 hier.depth
from 
 hier
inner join chapters c on hier.id = c.id
left outer join chapters p on hier.id_parent = p.id
order by
 hier.depth;

drop temporary table if exists hier;
drop temporary table if exists tmp;

end #

delimiter ;

Hope it helps :)

0

精彩评论

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