Avatar billede Droa Seniormester
05. september 2010 - 12:40 Der er 2 kommentarer og
1 løsning

Query som bider sig selv i halen?

Jeg har en table der ser sådan her ud

cat_id, int(255)
cat_name, varchar(255)
parent_cat_id, int(255), null

hvor parent_cat_id referere til cat_id på et andet element

så man kan lave et kategori træ, med under kategorier


cat_id = 1, cat_navn = "Uorganisk", parent_cat_id = null
cat_id = 2, cat_navn = "Metal", parent_cat_id = 1
cat_id = 3, cat_navn = "Jern", parent_cat_id = 2
cat_id = 3, cat_navn = "Copper", parent_cat_id = 2



-Uorganisk
--Metal
---Jern
---Copper


jeg vil igenne PHP lave en UL med opstillingen af kategorierne, og underkategorier, kan man gøre det med en SQL Query?
og må jeg se et eksempel, da jeg ikke er så meget inde i SQL?
mange tak
Avatar billede arne_v Ekspert
06. september 2010 - 04:16 #1
Det er ikke ret nemt at lave i MySQL.

Mit forslag vil være at lave det i PHP.

Eksempel:

<?php
class Rec {
    public $id;
    public $name;
    public $parent_id;
    public function __construct($id, $name, $parent_id) {
        $this->id = $id;
        $this->name = $name;
        $this->parent_id = $parent_id;
    }
}

function load() {
    $con = new mysqli('localhost', 'root', '', 'Test');
    $stmt = $con->prepare('SELECT cat_id,cat_name,parent_cat_id FROM cat');
    $stmt->execute();
    $stmt->store_result();
    $stmt->bind_result($id, $name, $parent_id);
    while ($stmt->fetch()) {
        $data[$id] = new Rec($id, $name, $parent_id);
    }
    $stmt->close();
    $con->close();
    return $data;
}

function printrec($data, $parent_id, $header, $footer, $start, $end) {
    echo $header;
    foreach($data as $d) {
        if($d->parent_id == $parent_id) {
            echo $start . $d->name . $end;
            printrec($data, $d->id, $header, $footer, $start, $end);
        }
    }
    echo $footer;
}

function printall($data, $header, $footer, $start, $end) {
    printrec($data, null, $header, $footer, $start, $end);
}

$data = load();
printall($data, "<ul>\r\n", "</ul>\r\n", "<li>", "</li>\r\n");
?>
Avatar billede Droa Seniormester
14. oktober 2010 - 10:00 #2
undskyld den lange svartid, jeg havde så godt som opgivet denne tråd, men mange tak for svaret, det var lige sådan et jeg skulle bruge... ligger du lige et svar?
Avatar billede arne_v Ekspert
14. oktober 2010 - 14:17 #3
svar
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Computerworld tilbyder specialiserede kurser i database-management

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester