Does a single quote cause MySQL performance loss?
MYSQL performance loss caused by a single quote
It is inevitable to encounter some dissatisfaction in life, some of which come from ourselves, and some of which do not. Today is the winter solstice, which is said to be the shortest day and longest night in the Northern Hemisphere. Today we are going to share that one of my colleagues mentioned the huge difference between adding single quotes or not, which is very meaningful for MYSQL performance optimization.
As we just said, there will inevitably be some dissatisfaction in life. For example, we use a string type field as the primary key. On the surface, this is too unsatisfactory. However, it has also been proven to be useful. of. The problem arises. When single quotes are added to the field value in the query statement, the query time differs by a hundred times!
The test table I created looks like this:
CREATE TABLE `foo` ( `key` VARCHAR(10) NOT NULL, `time` INT(11) NOT NULL, PRIMARY KEY (`key`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8;
Then insert more than 300,000 pieces of data, and then execute the following SQL statement:
SELECT * FROM `foo` WHERE `key` =1293322797
The query takes 0.1288 seconds, It takes about this long, and then, add single quotes to 1293322797:
SELECT * FROM `foo` WHERE `key` ='1293322797'
The query takes 0.0009 seconds, which is basically a 100-fold difference! ! ! In other words, without adding single quotes, the performance of MYSQL is reduced by 100 times, which is a shocking ratio!
Later, I used EXPLAIN to run the above two statements respectively, as shown in the two pictures below:
When there are no single quotes
With When using single quotes
#It is obvious that the main index is not used without using single quotes, and a full table scan is performed. Using single quotes can use the upper index.
Later, I tested them separately using greater than, and the returned result sets were the same, and their time-consuming was the same as above. I used EXPLAIN to test, and it was the same as above.
SELECT * FROM `foo` WHERE `key` >1293322797 SELECT * FROM `foo` WHERE `key` >'1293322797'
With single quotes and without Adding single quotes makes such a big difference! It will have such a big impact on mysql performance.
Later, I changed the field key to the INT type. At this time, there is no difference whether to add single quotes or not. EXPLAIN shows that they can also use the main index, but key_len becomes shorter.
Recommended: "mysql tutorial"
The above is the detailed content of Does a single quote cause MySQL performance loss?. 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

MySQL is an open source relational database management system, mainly used to store and retrieve data quickly and reliably. Its working principle includes client requests, query resolution, execution of queries and return results. Examples of usage include creating tables, inserting and querying data, and advanced features such as JOIN operations. Common errors involve SQL syntax, data types, and permissions, and optimization suggestions include the use of indexes, optimized queries, and partitioning of tables.

MySQL's position in databases and programming is very important. It is an open source relational database management system that is widely used in various application scenarios. 1) MySQL provides efficient data storage, organization and retrieval functions, supporting Web, mobile and enterprise-level systems. 2) It uses a client-server architecture, supports multiple storage engines and index optimization. 3) Basic usages include creating tables and inserting data, and advanced usages involve multi-table JOINs and complex queries. 4) Frequently asked questions such as SQL syntax errors and performance issues can be debugged through the EXPLAIN command and slow query log. 5) Performance optimization methods include rational use of indexes, optimized query and use of caches. Best practices include using transactions and PreparedStatemen

Apache connects to a database requires the following steps: Install the database driver. Configure the web.xml file to create a connection pool. Create a JDBC data source and specify the connection settings. Use the JDBC API to access the database from Java code, including getting connections, creating statements, binding parameters, executing queries or updates, and processing results.

MySQL is chosen for its performance, reliability, ease of use, and community support. 1.MySQL provides efficient data storage and retrieval functions, supporting multiple data types and advanced query operations. 2. Adopt client-server architecture and multiple storage engines to support transaction and query optimization. 3. Easy to use, supports a variety of operating systems and programming languages. 4. Have strong community support and provide rich resources and solutions.

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.

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

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.

The key to installing MySQL elegantly is to add the official MySQL repository. The specific steps are as follows: Download the MySQL official GPG key to prevent phishing attacks. Add MySQL repository file: rpm -Uvh https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm Update yum repository cache: yum update installation MySQL: yum install mysql-server startup MySQL service: systemctl start mysqld set up booting
