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

Jak zobrazit kategorie, podkategorie, podkategorie ve vybraném seznamu - php/mysql?

Za předpokladu, že vaše dané pole je v $array, můžete to použít. Ale jak jsem vám již řekl, měli byste vybrat ID pro zpracování kategorií se stejným názvem a použít je jako hodnoty možností ve vašem výběrovém poli:

  $options = get_options($array);
  echo "<select>";
  foreach($options as $val) {
    echo "<option>".$val."</option>";
  }
  echo "</select>";

  function get_options($array, $parent="", $indent="") {
    $return = array();
    foreach($array as $key => $val) {
      if($val["parent category"] == $parent) {
        $return[] = $indent.$val["category name"];
        $return = array_merge($return, get_options($array, $val["category name"], $indent."&nbsp;&nbsp;&nbsp;"));
      }
    }
    return $return;
  }

Za předpokladu, že nyní máte ve svém poli id ​​jako "category_id" a "parent_category_id", můžete to použít. "x" před klíčem v $return je jen proto, aby se zabránilo tomu, že php změní vaše klíče, protože jsou numerické.

  $options = get_options($array);
  echo "<select>";
  foreach($options as $key => $val) {
    echo "<option value='".substr($key,1)."'>".$val."</option>";
  }
  echo "</select>";

  function get_options($array, $parent=0, $indent="") {
    $return = array();
    foreach($array as $key => $val) {
      if($val["parent_category_id"] == $parent) {
        $return["x".$val["category_id"]] = $indent.$val["category name"];
        $return = array_merge($return, get_options($array, $val["category_id"], $indent."&nbsp;&nbsp;&nbsp;"));
      }
    }
    return $return;
  }


  1. Jaký je problém roku 2038?

  2. vložit do výběru v MySQL s JDBC

  3. Jak zkopírovat tabulku v MySQL

  4. BOOLEAN nebo TINYINT zmatek