


Usage of count() in mysql large table and optimization of count() in mysql
The content this article brings to you is about the usage of count() in mysql large tables and the optimization of count() in mysql. It has certain reference value. Friends in need can refer to it. I hope it will be helpful to you. helped.
A single table contains 60 million data, but you cannot split it. You need to separately count how much data there is in the table, how many products A have, and how many products B have.
Before optimization, the table structure is as follows. In order to hide the content, I fuzzified the corresponding fields.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
|
This is a regular InnoDB table, so its count(*) is compared to MyISAM's The efficiency is much slower. The number of rows displayed by InnoDB is not very accurate, so I need to count it here. There are several strategies.
A total of 61500000 data
count(*) takes 1539.499 s
count(1) takes 907.581s
count(A) Count the index.
count(test6) Count the primary key.
Without exception, since this table is not optimized, any of the above will take thousands of seconds, which we cannot bear.
Let’s start to analyze and deal with this problem.
It is expected that the count(*) of the entire table should be normal within 200s, good within 100, and excellent within 50.
First of all, I extracted test6 from it and formed a separate table. Perform the operation.
A total of 61,500,000 data
count(*) takes 10.238s
count(1) takes 8.710s
count(test6) Perform the operation on the primary key count. It takes 12.957s
count(1)
is the most efficient, and is faster than the slowest count(pk)
52.0%.
Change the fields you can determine to the optimal value, for example:
varchar is more char. Although varchar can automatically allocate the size of storage space, .varchar needs to use 1 to 2 Additional bytes are used to record the length of the string and increase its update operation time.
datetime is changed to timestamp which is between 1978-2038
Finally use count(1 ) is the fastest time-consuming test, 168s. Although it is a bit slow, it is acceptable.
Summary:
Redesign the fields in your table and try to optimize its length. Don’t blindly use it Multiple varchar.
Use count(1) instead of count(*) to retrieve.
Related recommendations:
Code implementation of Infinitus classification in mysql
Summary of Mysql database optimization methods (must read)
The above is the detailed content of Usage of count() in mysql large table and optimization of count() in mysql. For more information, please follow other related articles on the PHP Chinese website!

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 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 is suitable for web development and rapid prototyping, and Python is suitable for data science and machine learning. 1.PHP is used for dynamic web development, with simple syntax and suitable for rapid development. 2. Python has concise syntax, is suitable for multiple fields, and has a strong library ecosystem.

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.

Laravel is a PHP framework for easy building of web applications. It provides a range of powerful features including: Installation: Install the Laravel CLI globally with Composer and create applications in the project directory. Routing: Define the relationship between the URL and the handler in routes/web.php. View: Create a view in resources/views to render the application's interface. Database Integration: Provides out-of-the-box integration with databases such as MySQL and uses migration to create and modify tables. Model and Controller: The model represents the database entity and the controller processes HTTP requests.

PHP originated in 1994 and was developed by RasmusLerdorf. It was originally used to track website visitors and gradually evolved into a server-side scripting language and was widely used in web development. Python was developed by Guidovan Rossum in the late 1980s and was first released in 1991. It emphasizes code readability and simplicity, and is suitable for scientific computing, data analysis and other fields.

I encountered a tricky problem when developing a small application: the need to quickly integrate a lightweight database operation library. After trying multiple libraries, I found that they either have too much functionality or are not very compatible. Eventually, I found minii/db, a simplified version based on Yii2 that solved my problem perfectly.

Article summary: This article provides detailed step-by-step instructions to guide readers on how to easily install the Laravel framework. Laravel is a powerful PHP framework that speeds up the development process of web applications. This tutorial covers the installation process from system requirements to configuring databases and setting up routing. By following these steps, readers can quickly and efficiently lay a solid foundation for their Laravel project.

Compared with other programming languages, MySQL is mainly used to store and manage data, while other languages such as Python, Java, and C are used for logical processing and application development. MySQL is known for its high performance, scalability and cross-platform support, suitable for data management needs, while other languages have advantages in their respective fields such as data analytics, enterprise applications, and system programming.
