4, index classification and command
classification
- Single-valued index: that is, an index contains only a single instance. A table can have multiple single-valued indexes.
- Unique index: The value of the indexed column must be unique, but empty values are allowed.
- Compound index: That is, an index contains multiple columns
The command
- Create:
CREATE [UNIQUE] INDEX indexName ON mytable
orALTER mytable ADD [UNIQUE] INDEX [indexName] ON
- Delete:
DROP INDEX [indexName] ON mytable
- To view:
SHOW INDEX FROM table_name
5. Rules for using indexes
- The case where an index needs to be created
- The primary key automatically creates a unique index
- Fields that are frequently queried should be indexed
- The foreign key relationship establishes indexes for fields associated with other tables
- Frequently updated fields are not indexed
- Indexes are not created for fields that are not needed in the WHERE condition
- Use the sorted fields in the query as indexes to improve sorting speed
- Statistics or grouping fields in the query
- A case where no index needs to be created
- Too few table records
- A watch that is often added, deleted, or modified
- Table fields with repeated and average data
6. Performance analysis
Explain (query execution plan). Using the Explain keyword, you can simulate the MySQL optimizer to execute SQL statements to see how MySQL handles your SQL statements and analyze performance bottlenecks in query statements or table structures.
Explain functions:
- The read order of the table
- Operation type of data read operation
- Which indexes are available
- Which indexes are actually used
- References between tables
- How many rows per table are queried by the optimizer
The Explain + SQL statement displays the following information:
Table header information:
- Id: Serial number of a SELECT query, containing a set of numbers representing the properties of the query to perform the SELECT clause or operation table
- The ids are the same and the execution sequence is from top to bottom
- The ID is different. For sub-query, the ID sequence increases. The id with a larger value has a higher priority and is executed first.
- There’s the same id and there’s a different ID, and the same ID is a group
- Select_type: specifies the query category. It is used to distinguish complex queries, such as common query, joint query, and subquery.
- SIMPLE: A SIMPLE select query, excluding subqueries and unions
- PRIMARY: If the query contains any complex subqueries, the outermost layer is marked as PRIMARY
- SUBQUERY: A SUBQUERY contained in a SELECT or WHERE statement.
- DERIVED: The subqueries contained in the FROM list are labeled DERIVED, and MYSLQ executes these subqueries recursively, putting the results in temporary tables.
- UNION: If the second select appears after the UNION, it is marked as UNION
- UNION RESULT: Select the RESULT from the UNION table
- Table: Shows which tables this row is about.
- Type: access type array. From good to bad system – > const – > eq_ref – > ref – > range – > index – > All
- System: The table has only one row, which is equivalent to the system table.
- Const: found by index once, const is used to compare primary key or unique index. If you place the primary key in the WHERE list, MySQL converts the query to a constant.
- Eq_ref: Unique index scan. For each index key, only one record in the table matches it, usually a primary key or unique index key scan.
- Ref: a non-unique index scan that returns all rows matching a single value. It is essentially an index access that returns all rows that match a single value, and may find rows with multiple conditions, a mixture of lookup and scan.
- Range: Retrives only a given range, using an index to select rows, often in between, <, >, and in where statements. Don’t scan all indexes.
- Index: The difference between index and All is that index only scans the index tree. The index file is much smaller than the actual data. Although index is also read from the entire table, index is read from the index, and All is read from the hard disk. For example, retrieve the object with the primary key ID.
- All: traverses the entire table to find matching rows.
- Possible_key: Displays one or more possible indexes that can be applied to the table. The fields involved in the query are listed if there is an index on them. But not necessarily the actual query used.
- Key: indicates the actual used index. If the value is null, no index is used. If an overridden index is used in the query, it only appears in the key list.
- Key_len: indicates the number of bytes used in the index. This column is used to calculate the length of the index used in the query. The shorter the better without losing precision. The displayed length is not the actual length, calculated according to the table definition.
- Ref: Shows which column of the index is used. Which columns or constants are used to find values on index columns.
- Rows: Approximate estimate of the number of rows to read to find the desired record based on table statistics and index selection.
- Extra: Contains important information not suitable for display in other columns.
- Using filesort (×) : indicates that MySQL uses an external index sort for data, instead of reading the data in the order in which the table is read.
- Using temporary (×) : A temporary table is used to hold intermediate results. Common in sort order by and group by queries.
- Using index (√) : indicates that an overwrite index occurred in the corresponding SELECT operation, avoiding the access to the data row of the table. Using WHERE indicates that the index is used to perform a lookup of the index key value. No Using WHERE table name index is used to read data, not to find actions.
- Overwrite index: select columns that can be obtained only from the index, without reading rows, that is, the query column is overwritten by the created index.
- Using WHERE: Indicates that where filtering is used
- Using join buffer: The join buffer is used
- Impossible WHERE: The value of where is always false and cannot be obtained to obtain any tuple.