


Which MySQL Index Is More Efficient for Range Queries: Leading with High or Low Cardinality Column?
Nov 29, 2024 am 02:55 AMIndex Optimization for Range Queries
Columns with higher cardinality contribute to more efficient indices in MySQL. However, in the case of range queries, an exception applies.
Problem Statement
Consider a table with the following structure:
CREATE TABLE `files` ( `did` int(10) UNSIGNED NOT NULL DEFAULT '0', `filename` VARBINARY(200) NOT NULL, `ext` VARBINARY(5) DEFAULT NULL, `fsize` DOUBLE DEFAULT NULL, `filetime` DATETIME DEFAULT NULL, PRIMARY KEY (`did`,`filename`), KEY `fe` (`filetime`,`ext`), -- Option 1 KEY `ef` (`ext`,`filetime`) -- Option 2 ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
Filetimes are distinct, while there are a limited number of ext values (i.e., higher cardinality for filetime, lower cardinality for ext). A query involves both columns with the following conditions:
WHERE ext = '...' AND filetime BETWEEN ... AND ...
Which index, fe or ef, is more optimal?
Answer
Surprisingly, the index with ext as the first column, despite its lower cardinality, is more efficient for this query.
Explanation
MySQL's optimizer analyzes index alternatives and chooses the one with the lowest cost. Using the optimizer trace, we can observe the reasoning behind this choice.
For fe (filetime first), MySQL estimates that it would need to scan 16684 rows to find 'gif' files, even with the range condition on filetime.
For ef (ext first), however, it estimates that it can use both index columns and quickly drill down to the appropriate rows, resulting in a cost of only 646.61. MySQL chooses this index as it can use more key parts, making the search more efficient.
Conclusions
- Prioritize columns involved in equality tests in the index, regardless of cardinality.
- The query plan will not extend beyond the first 'range' column.
- In this context, cardinality is irrelevant for composite indices and range queries.
- InnoDB can utilize index columns beyond those used for filtering ("Using index condition").
The above is the detailed content of Which MySQL Index Is More Efficient for Range Queries: Leading with High or Low Cardinality Column?. For more information, please follow other related articles on the PHP Chinese website!

Hot Article

Hot tools Tags

Hot Article

Hot Article Tags

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

Reduce the use of MySQL memory in Docker

How do you alter a table in MySQL using the ALTER TABLE statement?

How to solve the problem of mysql cannot open shared library

What is SQLite? Comprehensive overview

Run MySQl in Linux (with/without podman container with phpmyadmin)

Running multiple MySQL versions on MacOS: A step-by-step guide

What are some popular MySQL GUI tools (e.g., MySQL Workbench, phpMyAdmin)?

How do I configure SSL/TLS encryption for MySQL connections?
