Heim > Artikel > Backend-Entwicklung > Das Prinzip der unendlichen Klassifizierung in PHP
Was ist eine unendliche Klassifizierung? Genau wie beim Erstellen eines neuen Ordners unter Windows können Sie einen neuen Ordner unter dem neu erstellten Ordner erstellen, und dies wird in einer Endlosschleife fortgesetzt. Dasselbe gilt für unendliche Kategorien in Unterkategorien, und die Unterkategorien können in Unterkategorien unterteilt werden, und dies kann in einer Endlosschleife fortgesetzt werden.
Wie erreicht PHP also seine unendliche Klassifizierung? Wie kann ich die verschiedenen Kategorien einzeln auflisten?
Zunächst gehen wir davon aus, dass es eine solche dreistufige Klassifizierung gibt: News→PHP News→PHP6.0 ist out.
Wenn wir die Nachricht „PHP6.0 ist draußen“ finden möchten, können wir zuerst auf die Nachrichten klicken und dann auf die PHP-Nachrichten klicken, um sie herauszufinden. Mit anderen Worten, wir können Ebene für Ebene durch die Großvaterklasse suchen. und umgekehrt. Solange wir die übergeordnete Klasse einer Unterklasse kennen, können wir sie finden. Auf diese Weise können wir beim Entwerfen der Datenbank ein zusätzliches Feld der übergeordneten Klassen-ID entwerfen, um unbegrenzte Klassifizierungsfunktionen zu erreichen.
<code>//我们建一个表"class" <span><span>CREATE</span><span>TABLE</span><span>`class`</span> ( <span>`id`</span><span>int</span>(<span>11</span>) <span>NOT</span><span>NULL</span> auto_increment COMMENT <span>'分类id'</span>, <span>`f_id`</span><span>int</span>(<span>11</span>) <span>NOT</span><span>NULL</span> COMMENT <span>'父id'</span>, <span>`name`</span><span>varchar</span>(<span>25</span>) <span>collate</span> gbk_bin <span>NOT</span><span>NULL</span> COMMENT <span>'分类名称'</span>, <span>PRIMARY</span><span>KEY</span> (<span>`id`</span>) ) ENGINE=MyISAM <span>DEFAULT</span> CHARSET=gbk <span>COLLATE</span>=gbk_bin AUTO_INCREMENT=<span>1</span> ;</span>//首先我们往数据库里插入‘新闻’这个大分类,因为‘新闻’是最大分类,上面没有父类了,所以我把它的f_id设置为0。 <span><span>INSERT</span><span>INTO</span><span>`class`</span> (<span>`id`</span>, <span>`f_id`</span>, <span>`name`</span>) <span>VALUES</span>(<span>1</span>, <span>0</span>, <span>'新闻'</span>);</span> //id这个字段是自动增长的,可以不写值。 //然后我们再往数据库里插入‘PHP新闻’这个分类,它的父类‘新闻’的id是1,所以它的f_id设置为1。 <span><span>INSERT</span><span>INTO</span><span>`class`</span> (<span>`id`</span>, <span>`f_id`</span>, <span>`name`</span>) <span>VALUES</span>(<span>2</span>, <span>1</span>, <span>'PHP新闻'</span>);</span>//然后我们再往数据库里插入‘PHP6.0出来了’这个分类,它的父类‘PHP新闻’的id是2,所以它的f_id设置为2。 <span><span>INSERT</span><span>INTO</span><span>`class`</span> (<span>`id`</span>, <span>`f_id`</span>, <span>`name`</span>) <span>VALUES</span>(<span>3</span>, <span>2</span>, <span>'PHP6.0出来了'</span>);</span>//同理,我们可以这样一直往下插入分类,也就达到了无限分类。 //我们可以发现插入一个分类的原则关键是找到这个分类的父类的id,然后作为这个分类的f_id字段的值。 //假设要插入跟‘新闻’同一个级别的分类‘技术’,也就是说它也是最大分类,上面没有父类了,那么它的f_id也设置为0; <span><span>INSERT</span><span>INTO</span><span>`class`</span> (<span>`id`</span>, <span>`f_id`</span>, <span>`name`</span>) <span>VALUES</span>(<span>4</span>, <span>0</span>, <span>'技术'</span>);</span>//在‘技术’下面又有一个分类‘PHP技术’,那么我们怎么插入呢,首先找到‘PHP技术’的父类‘技术’的id,然后作为自己的f_id字段的值。 <span><span>INSERT</span><span>INTO</span><span>`class`</span> (<span>`id`</span>, <span>`f_id`</span>, <span>`name`</span>) <span>VALUES</span>(<span>5</span>, <span>4</span>, <span>'PHP技术'</span>);</span>//看到这里,想必大家应该都明白怎么往数据库里插入各个分类了。就不再举例了。</code>Wir wissen bereits, wie man jede Kategorie in die Datenbank einfügt, aber wie listen wir jede Kategorie auf?
<code><span><span><span><?php</span> header(<span>"Content-type:text/html;charset=utf-8"</span>); <span>$db</span>=<span>new</span> mysqli(<span>"localhost"</span>,<span>"root"</span>,<span>""</span>,<span>"news_php100"</span>) ; <span>//实例化一个数据库连接。使用这个前一定要确保已经加载了mysqli类库,或者用mysql_connect这个方式连接。 </span><span>if</span>(mysqli_connect_errno()){ <span>echo</span><span>"链接失败:"</span>.mysqli_connect_error(); <span>exit</span>(); } <span>$db</span>->query(<span>"set names utf8"</span>); <span>$result</span>=<span>$db</span>->query(<span>"select name from class where f_id=0"</span>); <span>//查找f_id=0的分类,也就是查找每一个大类。</span><span>while</span>(<span>$row</span>=<span>$result</span>->fetch_assoc()){ <span>echo</span><span>$row</span>[<span>'name'</span>].<span>"<br>"</span>; <span>//这样就把每个大类<strong>循环</strong>出来了。</span> } <span>//同样我们可以把新闻的子类<strong>循环</strong>出来。</span><span>$result</span>=<span>$db</span>->query(<span>"select * from class where f_id=1"</span>); <span>//查找f_id=1的分类,也就是查找‘新闻’的子类。</span><span>while</span>(<span>$row</span>=<span>$result</span>->fetch_assoc()){ <span>echo</span><span>$row</span>[<span>'name'</span>].<span>"<br>"</span>; <span>//这样就把‘新闻’的子类<strong>循环</strong>出来了。注意:只是子类,不包括孙子类。</span> } <span>//写到这里,我们会发现一个问题,如果这个分类是10级分类,难道我们要写10个<strong>循环</strong>把它每个子类<strong>循环</strong>出来?如果是更多级分类呢,这样写显然是不现实的。</span><span>//那又有什么办法解决呢?我们可以写一个递归的函数,把f_id作为参数传入,不断<strong>循环</strong>每一个f_id的值,也就是说把每一个f_id值的子类<strong>循环</strong>出来。</span><span>//首先我们把各个分类的值保存在一个二维数组中,在下面的<strong>递归函数</strong>里有用。</span><span>$result</span>=<span>$db</span>->query(<span>"select * from class"</span>); <span>while</span>(<span>$row</span>=<span>$result</span>->fetch_assoc()){ <span>$arr</span>[]=<span>array</span>(<span>$row</span>[id],<span>$row</span>[f_id],<span>$row</span>[name]); <span>//每一行保存一个分类的id,f_id,name的信息。</span> } <span><span>function</span><span>fenlei</span><span>(<span>$f_id</span>=<span>0</span>)</span>{</span><span>//$f_id初始化为0,也就是从最大分类开始<strong>循环</strong>.</span><span>global</span><span>$arr</span>; <span>//声明$arr为<strong>全局变量</strong>才可在函数里引用。</span><span>for</span>(<span>$i</span>=<span>0</span>;<span>$i</span><count(<span>$arr</span>);<span>$i</span>++){ <span>//对每个分类进行<strong>循环</strong>。</span><span>if</span>(<span>$arr</span>[<span>$i</span>][<span>1</span>]==<span>$f_id</span>){ <span>//$arr[$i][1]表示第$i+1个分类的f_id的值。开始$f_id=0,也就是把f_id=0的分类输出来。</span><span>echo</span><span>$arr</span>[<span>$i</span>][<span>2</span>].<span>"<br>"</span>; <span>//$arr[$i][1]表示第$i+1个分类的name的值。</span> fenlei(<span>$arr</span>[<span>$i</span>][<span>0</span>]); <span>//$arr[$i][1]表示第$i+1个分类的id的值。进行递归,也就是把自己的id作为f_id参数把自己的子类再<strong>循环</strong>出来。</span> } } } <span>?></span></span></span></span></code>
http://blog.csdn.net/kao331431214/article/details/5425698Das Obige stellt das Prinzip der unbegrenzten Klassifizierung in PHP vor, einschließlich inhaltlicher Aspekte. Ich hoffe, dass es für Freunde hilfreich ist, die sich für PHP-Tutorials interessieren.