Database Optimization Design_PHP Tutorial
Many times in our projects, as our needs continue to change, we need to add fields to the original library table structure to meet our business needs.
Give a simple example:
I need a database table to store user information for a website. The user information needs to include (whether the account is an active account, whether the account is bound to an email address, whether the account has purchased products, whether the account has expired... etc.). Under normal circumstances, we may design this database table like this:
<span CREATE</span> <span TABLE</span> <span '</span><span ACCOUNT</span><span '</span><span ( `ID` </span><span int</span>(<span 22</span>) <span NOT</span> <span NULL</span> AUTO_INCREMENT, <span --</span><span 自增id</span> `F001` <span TINYINT</span>(<span 1</span>) <span NOT</span> <span NULL</span>, <span --</span><span 是否活跃(1:是/0:否)</span> `F002` <span TINYINT</span>(<span 1</span>) <span NOT</span> <span NULL</span>, <span --</span><span 是否绑定 (1:是/0:否)</span> `F003` <span TINYINT</span>(<span 1</span>) <span NOT</span> <span NULL</span>, <span --</span><span 是否购买产品 (1:是/0:否)</span> `F004` <span TINYINT</span>(<span 1</span>) <span NOT</span> <span NULL</span>, <span --</span><span 是否过期 (1:是/0:否)</span> <span PRIMARY</span> <span KEY</span>(<span '</span><span ID</span><span '</span><span ) ) ENGINE</span><span =</span>InnoDB AUTO_INCREMENT<span =</span><span 1</span> <span DEFAULT</span> CHARSET<span =</span>utf8;
If designed according to the above method, then when the requirements change, such as adding a field, whether the account is valid. Then we need to add another field `F005`, which will make management very troublesome. When adding a new field, all or historical data need to be updated, which can easily lead to data loss.
So, how to solve this problem and reduce the impact of the correlation between data fields as much as possible. Now there is a way to integrate all these fields into one field. For example: the `FLAG` field is stored in decimal notation (the first digit: 1: active, 0: inactive. The second digit: 1: bound, 2: unbound. The third digit: 1: purchased product , 0: Not purchased....), explain: If the value of this field is 5, converted to binary it is 101, the first digit is 1, the second digit is 0, and the third digit is 1. Then it means that the account is "Active, unbound, and purchased products." What are the benefits of this approach? The advantage is that the correlation between each type is very small, and updating one field type will not affect other fields. So, with this design, how should we query it? Bitwise AND, for a specific situation, I can give an example. When I need to query all purchased products and active accounts, that is (the first and third digits are 1), we fill in the other digits with 0, that is, 101=5:
SQL statement query:
<span SELECT</span> <span *</span> <span FROM</span> ACCOUNT <span WHERE</span> F005<span &</span><span 5</span><span ></span><span 0</span>;
The above SQL statement can query the accounts that have purchased products and are active.
Then, when updating and modifying, you only need to update each binary bit to the required value in the background program. For example, if you just purchased and was active, that is, 101, you want to change it to purchased, but not active. , then use (5&1)=1, thereby setting the third bit to 0. Here is a PHP function that can handle the program business very well.
<?<span php </span><span /*</span><span * * 取按位与要写入的数据 * @param $param 原值 * @param $postData 提交的数据key=>value,key必须从1开始的数据,value必须为0或者(key-1)次方数 key代表位 </span><span */</span> <span function</span> getExtValue(<span $param</span> = 0,<span $postData</span> = <span array</span><span ()){ </span><span if</span>(!<span empty</span><span $postData</span><span ){ </span><span foreach</span>(<span $postData</span> <span as</span> <span $key</span>=><span $value</span><span ){ </span><span $tmp1</span> = <span pow</span>(2,(<span $key</span>-1<span )); </span><span if</span> (<span empty</span>(<span $key</span>) || !<span is_numeric</span>(<span $key</span>) || !<span is_numeric</span>(<span $value</span>) || (<span $value</span> != 0 && <span $value</span> !=<span $tmp1</span><span )){ </span><span continue</span><span ; } </span><span $param</span> = (<span $param</span> & (0xffff^<span $tmp1</span>)) | <span $value</span><span ; } } </span><span return</span> <span $param</span><span ; }</span>

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

AI Hentai Generator
Generate AI Hentai for free.

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

The combination of Vue.js and ASP.NET provides tips and suggestions for performance optimization and expansion of web applications. With the rapid development of web applications, performance optimization has become an indispensable and important task for developers. As a popular front-end framework, Vue.js combined with ASP.NET can help us achieve better performance optimization and expansion. This article will introduce some tips and suggestions, and provide some code examples. 1. Reduce HTTP requests The number of HTTP requests directly affects the loading speed of web applications. pass

How to correctly use and optimize the MySQL connection pool in ASP.NET programs? Introduction: MySQL is a widely used database management system that features high performance, reliability, and ease of use. In ASP.NET development, using MySQL database for data storage is a common requirement. In order to improve the efficiency and performance of database connections, we need to correctly use and optimize the MySQL connection pool. This article will introduce how to correctly use and optimize the MySQL connection pool in ASP.NET programs.

Translator | Reviewed by Chen Jun | Chonglou In the 1990s, when people mentioned software programming, it usually meant choosing an editor, checking the code into the CVS or SVN code base, and then compiling the code into an executable file. Corresponding integrated development environments (IDEs) such as Eclipse and Visual Studio can integrate programming, development, documentation, construction, testing, deployment and other steps into a complete software development life cycle (SDLC), thus improving the work of developers. efficiency. In recent years, popular cloud computing and DevSecOps automation tools have improved developers' comprehensive capabilities, making it easier for more enterprises to develop, deploy and maintain software applications. Today, generative AI is the next generation development

How to reconnect to MySQL in ASP.NET program? In ASP.NET development, it is very common to use the MySQL database. However, due to network or database server reasons, the database connection may sometimes be interrupted or time out. In this case, in order to ensure the stability and reliability of the program, we need to re-establish the connection after the connection is disconnected. This article will introduce how to reconnect MySQL connections in ASP.NET programs. To reference the necessary namespaces first, reference them at the head of the code file

The combination of Vue.js and ASP.NET enables the development and deployment of enterprise-level applications. In today's rapidly developing Internet technology field, the development and deployment of enterprise-level applications has become more and more important. Vue.js and ASP.NET are two technologies widely used in front-end and back-end development. Combining them can bring many advantages to the development and deployment of enterprise-level applications. This article will introduce how to use Vue.js and ASP.NET to develop and deploy enterprise-level applications through code examples. First, we need to install

How to correctly configure and use MySQL connection pool in ASP.NET program? With the development of the Internet and the increase in data volume, the demand for database access and connections is also increasing. In order to improve the performance and stability of the database, connection pooling has become an essential technology. This article mainly introduces how to correctly configure and use the MySQL connection pool in ASP.NET programs to improve the efficiency and response speed of the database. 1. The concept and function of connection pooling. Connection pooling is a technology that reuses database connections. At the beginning of the program,

The built-in objects in ASP.NET include "Request", "Response", "Session", "Server", "Application", "HttpContext", "Cache", "Trace", "Cookie" and "Server.MapPath": 1. Request, indicating the HTTP request issued by the client; 2. Response: indicating the HTTP response returned by the web server to the client, etc.

Overview of the recommended configuration for using Visual Studio for ASP.NET development on Linux: With the development of open source software and the popularity of the Linux operating system, more and more developers are beginning to develop ASP.NET on Linux. As a powerful development tool, Visual Studio has always occupied a dominant position on the Windows platform. This article will introduce how to configure VisualStudio for ASP.NE on Linux
