sql >> Databáze >  >> RDS >> Mysql

Efektivnější systém hierarchie

Myslím, že by mělo fungovat něco v tomto smyslu (netestováno, musí být přizpůsobeno vašim potřebám):

$q = mysql_query("SELECT id, parent_id, name FROM categories");
while ($r = mysql_fetch_row($q)) {
  $names[$r[0]] = $r[2];
  $children[$r[0]][] = $r[1];
}

function render_select($root=0, $level=-1) {
  global $names, $children;
  if ($root != 0)
    echo '<option>' . strrep(' ', $level) . $names[$root] . '</option>';
  foreach ($children[$root] as $child)
    render_select($child, $level+1);
}

echo '<select>';
render_select();
echo '</select>';

ještě zábavnějším způsobem, jak toho dosáhnout, je použití uložených procedur SQL, ale v tomto případě to může být příliš přehnané...



  1. Jak ladit postgresql uložené procedury?

  2. Jak se vyhnout nevyžádaným/zbytečným znakům při čtení dat z více jazyků?

  3. Jak se dotazovat na hodnoty z xml uzlů?

  4. Příklady JSON_MODIFY() v SQL Server (T-SQL)