Table of Contents
Reply content:
Home Backend Development PHP Tutorial What is the data structure of the three-level rebate system? Modify and query issues

What is the data structure of the three-level rebate system? Modify and query issues

Aug 04, 2016 am 09:21 AM
mysql oracle php postgresql

I need to make a three-level rebate project. The requirement is to be able to view someone's first-level, second-level and third-level users and change the person's superior. The data structure was originally designed like this:
uid 1 2 3
User id belongs to the superior belongs to the superior belongs to the superior superior
1 0 0 0
2 1 0 0
3 2 1 0
4 3 2 1
5 4 3 2
6 3 2 1

User 1’s superior is platform, and the three superior levels are all 0. User 6’s superior is user 3, its superior is 2, and its superior is 1. This structure is convenient for query, but if you modify the default superior, if This person has 100,000 subordinates, and the superiors of these 100,000 people also need to make modifications. The amount of modification will be too large.
If changed to:
uid 1
User id belongs to the superior
1 0
2 1
3 2
4 3
5 4
6 3
Then to query all users in the third level from this user, you need to query the user first All the second-level users, and then query all the subordinates of all the second-level users, the query volume is also very large.
I would like to ask if you have any compromise solutions?

Reply content:

I need to make a three-level rebate project. The requirement is to be able to view someone's first-level, second-level and third-level users and change the person's superior. The data structure was originally designed like this:
uid 1 2 3
User id belongs to the superior belongs to the superior belongs to the superior superior
1 0 0 0
2 1 0 0
3 2 1 0
4 3 2 1
5 4 3 2
6 3 2 1

User 1’s superior is platform, and the three superior levels are all 0. User 6’s superior is user 3, its superior is 2, and its superior is 1. This structure is convenient for query, but if you modify the default superior, if This person has 100,000 subordinates, and the superiors of these 100,000 people also need to make modifications, and the amount of modification will be too large.
If it is changed to:
uid 1
The superior the user id belongs to
1 0
2 1
3 2
4 3
5 4
6 3
Then to query all the users at the third level from this user, you need to query the user first All the second-level users, and then query all the subordinates of all the second-level users, the query volume is also very large.
I would like to ask if you have any compromise solutions?

mysql foreign key + recursion

It is recommended to adopt the second solution, which only retains the uid and pid fields. This design supports any level of relationships, and if there is an update, the number of records modified will be relatively small.
Multi-level query can be simplified through the recursive query syntax of each database, such as the CONNECT BY statement in Oracle, or the CTE of SQLSQLER, etc.

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

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

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

PHP's Purpose: Building Dynamic Websites PHP's Purpose: Building Dynamic Websites Apr 15, 2025 am 12:18 AM

PHP is used to build dynamic websites, and its core functions include: 1. Generate dynamic content and generate web pages in real time by connecting with the database; 2. Process user interaction and form submissions, verify inputs and respond to operations; 3. Manage sessions and user authentication to provide a personalized experience; 4. Optimize performance and follow best practices to improve website efficiency and security.

PHP and Python: Code Examples and Comparison PHP and Python: Code Examples and Comparison Apr 15, 2025 am 12:07 AM

PHP and Python have their own advantages and disadvantages, and the choice depends on project needs and personal preferences. 1.PHP is suitable for rapid development and maintenance of large-scale web applications. 2. Python dominates the field of data science and machine learning.

PHP and Python: Different Paradigms Explained PHP and Python: Different Paradigms Explained Apr 18, 2025 am 12:26 AM

PHP is mainly procedural programming, but also supports object-oriented programming (OOP); Python supports a variety of paradigms, including OOP, functional and procedural programming. PHP is suitable for web development, and Python is suitable for a variety of applications such as data analysis and machine learning.

PHP: Handling Databases and Server-Side Logic PHP: Handling Databases and Server-Side Logic Apr 15, 2025 am 12:15 AM

PHP uses MySQLi and PDO extensions to interact in database operations and server-side logic processing, and processes server-side logic through functions such as session management. 1) Use MySQLi or PDO to connect to the database and execute SQL queries. 2) Handle HTTP requests and user status through session management and other functions. 3) Use transactions to ensure the atomicity of database operations. 4) Prevent SQL injection, use exception handling and closing connections for debugging. 5) Optimize performance through indexing and cache, write highly readable code and perform error handling.

How to start mysql by docker How to start mysql by docker Apr 15, 2025 pm 12:09 PM

The process of starting MySQL in Docker consists of the following steps: Pull the MySQL image to create and start the container, set the root user password, and map the port verification connection Create the database and the user grants all permissions to the database

Why Use PHP? Advantages and Benefits Explained Why Use PHP? Advantages and Benefits Explained Apr 16, 2025 am 12:16 AM

The core benefits of PHP include ease of learning, strong web development support, rich libraries and frameworks, high performance and scalability, cross-platform compatibility, and cost-effectiveness. 1) Easy to learn and use, suitable for beginners; 2) Good integration with web servers and supports multiple databases; 3) Have powerful frameworks such as Laravel; 4) High performance can be achieved through optimization; 5) Support multiple operating systems; 6) Open source to reduce development costs.

MySQL's Role: Databases in Web Applications MySQL's Role: Databases in Web Applications Apr 17, 2025 am 12:23 AM

The main role of MySQL in web applications is to store and manage data. 1.MySQL efficiently processes user information, product catalogs, transaction records and other data. 2. Through SQL query, developers can extract information from the database to generate dynamic content. 3.MySQL works based on the client-server model to ensure acceptable query speed.

PHP vs. Python: Use Cases and Applications PHP vs. Python: Use Cases and Applications Apr 17, 2025 am 12:23 AM

PHP is suitable for web development and content management systems, and Python is suitable for data science, machine learning and automation scripts. 1.PHP performs well in building fast and scalable websites and applications and is commonly used in CMS such as WordPress. 2. Python has performed outstandingly in the fields of data science and machine learning, with rich libraries such as NumPy and TensorFlow.

See all articles