This article brings you relevant knowledge about mysql, which mainly introduces related issues about performance tuning, mainly introduces the relevant content of partition tables. For users, partitioning The table is an independent logical table, but the bottom layer is composed of multiple physical sub-tables. Let's take a look at it together. I hope it will be helpful to everyone.
Recommended learning: mysql video tutorial
For users, the partition table is an independent logical table, but the bottom layer is Composed of multiple physical sub-tables. The partition table is a black box that completely encapsulates the underlying implementation and is transparent to the user. Multiple table files named using # to separate them can be seen from the file system.
Mysql uses the partition by clause to define the data stored in each partition when creating a table. When executing a query, the optimizer will filter those partitions that do not have the data we need based on the partition definition, so that the query does not need to scan all partitions.
The main purpose of partitioning is to divide the data into different tables, so that related data can be stored together.
Next, I will talk about the partition table from the following six aspects, namely the application scenarios of the partition table, the limitations of the partition table, the principle of the partition table, the types of the partition table, how to use the partition table, and how to use the partition table. Things to pay attention to when making a table.
1. Application scenarios of partition tables
1. The table is so large that it cannot all be placed in the memory, or there is only hot data in the last part of the table, and the rest is historical data .
2. Partitioned table data is easier to maintain
(1) To delete a large amount of data in batches, you can use the method of clearing the entire partition
(2) Optimize an independent partition , check, repair and other operations
3. The data of the partition table can be distributed on different physical devices, thereby efficiently utilizing multiple hardware devices
4. The partition table can be used to avoid certain Some special bottlenecks
(1) Mutually exclusive access of a single index of innodb
(2) Inode lock competition of ext3 file system
5. Can be backed up and restored independently Partition
2. Limitations of partition table
1. A table can only have a maximum of 1024 partitions. In version 5.7, it can support 8196 partitions
2. In the early MySQL, the partition expression must be an integer or an expression that returns an integer. In MySQL 5.5, columns can be used directly for partitioning in some scenarios.
3. If there are primary key or unique index columns in the partition field, then all primary key columns and unique index columns must be included.
4. Partitioned tables cannot use foreign key constraints
3. Principle of partitioned tables
Partitioned tables are implemented by multiple related underlying tables. This underlying table is also identified by a handle object, and we can directly access each partition. The storage engine manages each underlying table of the partition in the same way as it manages an ordinary table (all underlying tables must use the same storage engine). The index knowledge of the partition table adds an identical index to each underlying table. From the perspective of the storage engine, the underlying table is no different from an ordinary table, and the storage engine does not need to know whether it is an ordinary table or part of a partitioned table. The operation of the partition table is carried out according to the following operation logic:
1. Select query
When querying a partition table, the partition layer first opens and locks all For the underlying table, the optimizer first determines whether some partitions can be filtered, and then calls the corresponding storage engine interface to access the data of each partition
2. Insert operation
When writing When a record is entered, the partition layer first opens and locks all underlying tables, then determines which partition accepts the record, and then writes the record to the corresponding underlying table.
3. Delete operation
When deleting a record, the partition layer first opens and locks all underlying tables, then determines the partition corresponding to the data, and finally performs the corresponding Delete the underlying table.
4. Update operation
When updating a record, the partition layer first opens and locks all underlying tables, and mysql first determines which partition the record needs to be updated. , then take out the data and update it, then determine which partition the updated data should be in, and finally write to the underlying table and delete the underlying table where the source data is located.
Some operations support filtering. For example, when deleting a record, MySQL needs to find the record first. If the where condition happens to match the partition expression, all partitions that do not contain this record can be All are filtered out, which is also effective for update. If it is an insert operation, it will only hit one partition, and other partitions will be filtered out. MySQL first determines which partition this record belongs to, and then writes the record to the corresponding partition table without operating on any other partitions.
Although each operation will "first open and lock all underlying tables", this does not mean that the partition table locks the entire table during processing. If the storage engine can implement row-level locks by itself, such as innodb , the corresponding table lock will be released at the partition level.
Recommended learning: mysql video tutorial
The above is the detailed content of MySQL performance tuning partition table (summary sharing). For more information, please follow other related articles on the PHP Chinese website!

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于架构原理的相关内容,MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

方法:1、利用right函数,语法为“update 表名 set 指定字段 = right(指定字段, length(指定字段)-1)...”;2、利用substring函数,语法为“select substring(指定字段,2)..”。

mysql的msi与zip版本的区别:1、zip包含的安装程序是一种主动安装,而msi包含的是被installer所用的安装文件以提交请求的方式安装;2、zip是一种数据压缩和文档存储的文件格式,msi是微软格式的安装包。

转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。


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

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

Atom editor mac version download
The most popular open source editor

SublimeText3 Linux new version
SublimeText3 Linux latest version

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),
