递归解决无限级分类的问题
小弟手中有分类3406条,存在category表中。现在用递归解决分类,做成select,如下图:
下面是PHP代码,但是生成select后有错误:
<code>// $result是从数据库中读出的二维数组 $result = array(); while (($row = $info->fetch_array(MYSQLI_ASSOC)) != false) { // 改变数组的索引为分类的id $result[$row['id']] = $row; } $str = ''; $str .= "<select id="category">"; foreach ($result as $value) { if ($value['parent_id'] == 0) { $str .= "<option id="{$value[">{$value['title']}</option>"; $str .= get_children($value['id'], $result, 1); } } $str .= "</select>"; function get_children($id, &$result, $index) { $str = ''; foreach ($result as $key => $value) { if ($id == $value['parent_id']) { $str .= "<option id="{$value[">".str_repeat('---', $index)."{$value['title']}</option>"; $str .= get_children($value['id'], $result, $index + 1); unset($result[$value['id']]); // 存在并且去掉这个以为数组 //echo count($result).'<br>'; } } return $str; } // 打印出select echo $str; </code>
上面代码中,去掉unset执行最后的结果是对的,但是执行时间一般在八九秒。我的想法是存在这一条后把这一条从result结果集中去掉,这样的话以后循环的时候减少循环的次数,然后就能减少执行的时间,但是执行的结果是不对的,只存在省下面的一个地市,其余的地市没有了,研究了半天,也没有发现哪里错,请大神指正。
PS: 1。第一次发帖,不怎么会用,请谅解小弟。
2。有没有更好的办法递归3400多个分类。。
3.谢谢。。
回复内容:
小弟手中有分类3406条,存在category表中。现在用递归解决分类,做成select,如下图:
下面是PHP代码,但是生成select后有错误:
<code>// $result是从数据库中读出的二维数组 $result = array(); while (($row = $info->fetch_array(MYSQLI_ASSOC)) != false) { // 改变数组的索引为分类的id $result[$row['id']] = $row; } $str = ''; $str .= "<select id="category">"; foreach ($result as $value) { if ($value['parent_id'] == 0) { $str .= "<option id="{$value[">{$value['title']}</option>"; $str .= get_children($value['id'], $result, 1); } } $str .= "</select>"; function get_children($id, &$result, $index) { $str = ''; foreach ($result as $key => $value) { if ($id == $value['parent_id']) { $str .= "<option id="{$value[">".str_repeat('---', $index)."{$value['title']}</option>"; $str .= get_children($value['id'], $result, $index + 1); unset($result[$value['id']]); // 存在并且去掉这个以为数组 //echo count($result).'<br>'; } } return $str; } // 打印出select echo $str; </code>
上面代码中,去掉unset执行最后的结果是对的,但是执行时间一般在八九秒。我的想法是存在这一条后把这一条从result结果集中去掉,这样的话以后循环的时候减少循环的次数,然后就能减少执行的时间,但是执行的结果是不对的,只存在省下面的一个地市,其余的地市没有了,研究了半天,也没有发现哪里错,请大神指正。
PS: 1。第一次发帖,不怎么会用,请谅解小弟。
2。有没有更好的办法递归3400多个分类。。
3.谢谢。。
关系数据库中的无限深度树状关系的表示有两种常见方案:
- edge list tree(又写作adjacency list,即邻接表)
一行的表示类似于(子元素id, 父元素id)
- nested set tree(即左右值)
一行的表示类似于(当前元素左值, 当前元素右值)
相信楼主用的是前者,这样的坏处是需要递归查询。而后者更易于查询,一条sql即可搞定,见@沙渺 的这篇文章。
针对lz的问题,如果嵌套关系表示使用的是左右值方法,拿到全量数据的前提下,在PHP中也可以用O(n)方式迭代数据得到所有需要的子节点和深度等数据,非常简单。
如果只是需要在前端使用这些树状数据,那么公子的方案是最简单的,比用数据库邻接表、服务器端递归遍历简单多了。
关于nested set:
- WIKI: Nested Set Model
- Nested Set的主要使用流程(常用查询,增删节点的方式等)
- nested set与adjacency list效率比较,以及如何使用R-tree索引进行进一步提速
- 一个把edge list转化为nested set的mysql存储过程
这种东西干嘛要存到数据库中啊 =_=! http://www.soulteary.com/2013/05/10/jquery-city-select.html

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

PHP et Python ont chacun leurs propres avantages et choisissent en fonction des exigences du projet. 1.Php convient au développement Web, en particulier pour le développement rapide et la maintenance des sites Web. 2. Python convient à la science des données, à l'apprentissage automatique et à l'intelligence artificielle, avec syntaxe concise et adaptée aux débutants.

PHP est toujours dynamique et occupe toujours une position importante dans le domaine de la programmation moderne. 1) La simplicité de PHP et le soutien communautaire puissant le rendent largement utilisé dans le développement Web; 2) sa flexibilité et sa stabilité le rendent exceptionnelle dans la gestion des formulaires Web, des opérations de base de données et du traitement de fichiers; 3) PHP évolue et optimise constamment, adapté aux débutants et aux développeurs expérimentés.

PHP est utilisé pour créer des sites Web dynamiques, et ses fonctions principales incluent: 1. Générer du contenu dynamique et générer des pages Web en temps réel en se connectant à la base de données; 2. Traiter l'interaction utilisateur et les soumissions de formulaires, vérifier les entrées et répondre aux opérations; 3. Gérer les sessions et l'authentification des utilisateurs pour offrir une expérience personnalisée; 4. Optimiser les performances et suivre les meilleures pratiques pour améliorer l'efficacité et la sécurité du site Web.

Apache se connecte à une base de données nécessite les étapes suivantes: Installez le pilote de base de données. Configurez le fichier web.xml pour créer un pool de connexion. Créez une source de données JDBC et spécifiez les paramètres de connexion. Utilisez l'API JDBC pour accéder à la base de données à partir du code Java, y compris l'obtention de connexions, la création d'instructions, les paramètres de liaison, l'exécution de requêtes ou de mises à jour et de traitement des résultats.

PHP est largement utilisé dans le commerce électronique, les systèmes de gestion de contenu et le développement d'API. 1) E-commerce: Utilisé pour la fonction de panier et le traitement des paiements. 2) Système de gestion du contenu: utilisé pour la génération de contenu dynamique et la gestion des utilisateurs. 3) Développement des API: Utilisé pour le développement de l'API RESTful et la sécurité de l'API. Grâce à l'optimisation des performances et aux meilleures pratiques, l'efficacité et la maintenabilité des applications PHP sont améliorées.

PHP et Python ont leurs propres avantages et inconvénients, et le choix dépend des besoins du projet et des préférences personnelles. 1.Php convient au développement rapide et à la maintenance des applications Web à grande échelle. 2. Python domine le domaine de la science des données et de l'apprentissage automatique.

PHP est principalement la programmation procédurale, mais prend également en charge la programmation orientée objet (POO); Python prend en charge une variété de paradigmes, y compris la POO, la programmation fonctionnelle et procédurale. PHP convient au développement Web, et Python convient à une variété d'applications telles que l'analyse des données et l'apprentissage automatique.

PHP utilise les extensions MySQLI et PDO pour interagir dans les opérations de base de données et le traitement de la logique côté serveur, et traite la logique côté serveur via des fonctions telles que la gestion de session. 1) Utilisez MySQLI ou PDO pour vous connecter à la base de données et exécuter les requêtes SQL. 2) Gérer les demandes HTTP et l'état de l'utilisateur via la gestion de session et d'autres fonctions. 3) Utiliser les transactions pour assurer l'atomicité des opérations de base de données. 4) Empêcher l'injection de SQL, utiliser les connexions de gestion des exceptions et de clôture pour le débogage. 5) Optimiser les performances via l'indexation et le cache, écrivez du code très lisible et effectuez une gestion des erreurs.
