How to implement unlimited classification in PHP
Infinite classification is a design technique that is often used in development. This article mainly introduces the implementation method of infinite classification in PHP. If you need it, you can learn about it.
Infinite classification is a design technique that is often used in development, such as website directories, department structures, and article classifications. The author feels that it plays a great role in designing the hierarchical structure of tables. For example, on some platforms,
Fill in the inviter, it is a superior-subordinate relationship. The superior will have multiple subordinates, and the subordinates will have their own branches. Most of them are implemented using recursive ideas. Without further ado, let’s first review the implementation of recursion
Recursion (a programming technique in which a program calls itself):
1. $_GLOBALS[result]
2. static $result
3. Parameter reference &
Example: Traverse 1-10
$i=0; function deeploop( $i ){ global $i; $i++; echo $i; if( $i<10 ){ deeploop($i); } } function deeploop( ){ static $i=0; $i++; echo $i; if( $i<10 ){ deeploop($i); } } function deeploop( &$i=0 ){ $i++; echo $i; if( $i<10 ){ deeploop($i); } }
1. Unlimited classification implementation:
1. Set the parent id in the table design and set the top parent id to 0 to establish a family tree; each category needs to record its parent id. (pid=0 represents the top level)
id pid catename cateorder createtime (primary key id, parent id, category name, category sorting, creation time)
Examples: Category directory structure of website; Category structure of catering; Structure of comments
2. Unlimited classification of the full path (record all parent IDs in order in one field)
id path catename cateorder createtime (primary key id, parent id in comma-separated order, category name, category sorting, creation time)
Advantages and disadvantages:
Full path query is convenient; additionally, data maintenance is slightly more complicated when moving classification;
2. Example implementation (website directory):
Classification table:
#父级Id递归法 CREATE TABLE `deepcate`( `id` int(11) NOT NULL AUTO_INCREMENT PRIMARY KEY, `pid` int(11) NOT NULL DEFAULT 0, `catename` char(25) NOT NULL, `cateorder` int(6) , `createtime` date )ENGINE=INNODB default CHARSET=utf8; //数据 INSERT INTO `deepcate` VALUES(1,0,'图片',null,'2016-11-01'), ( 2,1,'美女',null,'2016-11-01'), ( 3,1,'新闻',null,'2016-11-01'), ( 4,2,'足球宝贝',null,'2016-11-01'), ( 5,2,'日韩明星',null,'2016-11-01'), ( 6,5,'美女写真',null,'2016-11-01'); #全路径 CREATE TABLE `qljcate` ( `id` int(11) NOT NULL, `path` char(255) , `catename` char(25) NOT NULL, `cateorder` int(6), `createtime` date )ENGINE=INNODB default CHARSET=utf8; INSERT INTO `qljcate` VALUES( 1,null,'图片',null,'2016-11-01'), ( 2,1,'美女图片',null,'2016-11-01'), ( 3,1,2,'足球宝贝',null,'2016-11-01'), ( 4,1,2,'日韩明星',null,'2016-11-01'), ( 5,1,2,4,'美女写真',null,'2016-11-01');
Get the directory path where the image is located:
#父级Id递归法 CREATE TABLE `deepcate`( `id` int(11) NOT NULL AUTO_INCREMENT PRIMARY KEY, `pid` int(11) NOT NULL DEFAULT 0, `catename` char(25) NOT NULL, `cateorder` int(6) , `createtime` date )ENGINE=INNODB default CHARSET=utf8; //数据 INSERT INTO `deepcate` VALUES(1,0,'图片',null,'2016-11-01'), ( 2,1,'美女',null,'2016-11-01'), ( 3,1,'新闻',null,'2016-11-01'), ( 4,2,'足球宝贝',null,'2016-11-01'), ( 5,2,'日韩明星',null,'2016-11-01'), ( 6,5,'美女写真',null,'2016-11-01'); #全路径 CREATE TABLE `qljcate` ( `id` int(11) NOT NULL, `path` char(255) , `catename` char(25) NOT NULL, `cateorder` int(6), `createtime` date )ENGINE=INNODB default CHARSET=utf8; INSERT INTO `qljcate` VALUES( 1,null,'图片',null,'2016-11-01'), ( 2,1,'美女图片',null,'2016-11-01'), ( 3,1,2,'足球宝贝',null,'2016-11-01'), ( 4,1,2,'日韩明星',null,'2016-11-01'), ( 5,1,2,4,'美女写真',null,'2016-11-01');
*be careful:
A mobile category cannot be moved below itself and its subcategories; a category can be deleted (only the lowest category can be deleted, and categories without subcategories; in other words, it can only be deleted from the lowest level).
Thinking about all the image categories under image types?
#pid 父级id实现法 function GetAllcate( $id,&$result=array() ){ $sql = "SELECT * FROM deepcate WHERE pid in ({$id})"; $query = mysql_query( $sql ); $row = mysql_fetch_assoc( $query ); if( mysql_num_rows($row)>0 ) { $idlist = array(); while( $row ){ $result[] = $row; $idlist[] = $row['id']; } $id = implode(',',$idlist); GetAllcate( $id,$result ); } $result = array_unique( $result ); return $result; }
This method is more suitable for querying all books and articles under the parent category. . . Of course, the full path can be obtained directly, so I won’t mention it here.
In actual operation, we can design a reasonable table structure according to the actual situation.
For example, if a chain store implements product management, there will be a superior-subordinate relationship in the store's account settings. Depending on the partition of the agent point, there may be such subordinates who have their own subordinates. Then using this unlimited classification method will be more flexible to face this. With this kind of relationship system, you only need to set each account level to set permission distribution for different stores.

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

If you are an experienced PHP developer, you might have the feeling that you’ve been there and done that already.You have developed a significant number of applications, debugged millions of lines of code, and tweaked a bunch of scripts to achieve op

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.

What are the magic methods of PHP? PHP's magic methods include: 1.\_\_construct, used to initialize objects; 2.\_\_destruct, used to clean up resources; 3.\_\_call, handle non-existent method calls; 4.\_\_get, implement dynamic attribute access; 5.\_\_set, implement dynamic attribute settings. These methods are automatically called in certain situations, improving code flexibility and efficiency.
