首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql 分区必须为主键

基础概念

MySQL 分区是将一个表或索引分解成多个更小、更易于管理的部分的技术。分区可以基于表中的一个或多个列的值进行,这些列称为分区键。分区可以提高查询性能、管理数据和优化备份操作。

分区类型

MySQL 支持多种分区类型,包括:

  1. RANGE 分区:基于分区键的范围进行分区。
  2. LIST 分区:基于分区键的离散值列表进行分区。
  3. HASH 分区:基于分区键的哈希函数结果进行分区。
  4. KEY 分区:类似于 HASH 分区,但使用 MySQL 提供的哈希函数。
  5. LINEAR HASH 和 LINEAR KEY 分区:线性版本的 HASH 和 KEY 分区,提供更均匀的分区分布。

应用场景

分区适用于以下场景:

  • 大数据表:当表的数据量非常大时,分区可以提高查询性能和管理效率。
  • 范围查询:对于基于某个范围的查询,分区可以显著提高性能。
  • 数据归档:可以将旧数据分区,便于归档和删除。
  • 备份和恢复:分区可以简化备份和恢复操作。

MySQL 分区必须为主键吗?

MySQL 分区并不要求分区键必须是主键,但有一些限制和要求:

  1. 分区键必须是索引的一部分:分区键必须是表的一个索引列。
  2. 分区键不能是 NULL:分区键列不能包含 NULL 值。
  3. 分区键的选择:分区键应该选择能够均匀分布数据的列,以避免数据倾斜。

示例

假设有一个包含大量数据的表 orders,我们可以按 order_date 进行分区:

代码语言:txt
复制
CREATE TABLE orders (
    order_id INT AUTO_INCREMENT,
    customer_id INT,
    order_date DATE,
    total_amount DECIMAL(10, 2),
    PRIMARY KEY (order_id, order_date)
) PARTITION BY RANGE (YEAR(order_date)) (
    PARTITION p0 VALUES LESS THAN (2010),
    PARTITION p1 VALUES LESS THAN (2015),
    PARTITION p2 VALUES LESS THAN (2020),
    PARTITION p3 VALUES LESS THAN MAXVALUE
);

在这个示例中,order_date 并不是主键,但它是分区键的一部分。

参考链接

总结

MySQL 分区并不要求分区键必须是主键,但分区键必须是索引的一部分,并且不能包含 NULL 值。选择合适的分区键可以提高查询性能和管理效率。通过合理的分区策略,可以更好地管理和优化大数据表。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

MySQL主键0和主键自排约束的关系

现在主键是没有0的,如果把某个id改成0的话,0不会变!...如果使用主键自排约束以前表里有0,再设置完主键自排以后所有的0又不会根据行数,而是直接按照自上而下的顺序从1开始排。...如果把表中的某个主键的数改成0,那直接就会进行排序放到正数前面,也就是说主键自排是允许有0存在的,那为什么本身存在的0要去修改成从1开始的递增序列呢?...哪怕没加主键自排以前只有一个0,加了主键自排以后还是会变成1。   开始有0,增加主键自排约束,0依次变为1,2,3,4.......   ...开始没0,增加主键自排约束,新添加的主键是0的行会根据行数自行变化,注意这里是新添加的行,使用的是insert。   开始没0,把某个主键的数修改成0,这个0会直接在排好序了再在表里显示出来。

4.3K30

mysql 联合主键_Mysql 创建联合主键

Mysql 创建联合主键 2008年01月11日 星期五 下午 5:21 使用primary key (fieldlist) 比如: create table mytable ( aa int, bb...char(8), cc date, primary key (aa,bb ) ); aa,bb联合主键 不知道是不是因为mysql(6.0)的版本问题,还是各版本都是这种情况,mysql中创建联合主键...TABLE t1( id … MySQL创建双主键 如下: CREATE TABLE `loginlog` ( `id` ) unsigned zerofill NOT NULL AUTO_INCREMENT...COMMENT ‘主键编号’, `IP` … mysql修改联合主键 参考 https://blog.csdn.net/BockSong/article/details/80933477 alter...涉及的知识点总结如下: One to One 映射关系 一对一单向外键(XML/Annotation) 一对一双向外键关联(XML/A … SQL Server中的联合主键、聚集索引、非聚集索引、mysql

8.3K20
  • mysql 分区键_mysql分区

    分区 5.1 版本range,list,hash,分区键,必须是int,或者表达式返回int类型; 5.5 版本 的range,list分区,已经支持非整数分区了; key分区,可以使用除blob,text...之外的类型列作为分区键; 如果存在主键/唯一键字段,则不能使用除主键/唯一键字段之外的其他字段进行分区。...同时hash分区只支持整数分区,而key分区支持使用除blob,text以外的其他类型; 与hash分区不同,创建可以分区表的时候,可以不指定分区键,默认会首先选择使用主键作为分区键;没有主键时,会选择非空唯一键作为分区键...; range分区中,null值会被当做最小值来处理; list分区中,null值必须出现在枚举列表中,否则不接受 hash/key,null值会被当做零值来处理; 分区管理 使用alter table...hash分区 如存在主键/唯一键字段,则只能使用其作为分区字段 columns 分区:partition by range colulmns(time); 多字段分区 : partition by range

    3.8K30

    mysql 主键自增语句_MySQL 自增主键

    MySQL 5.7 及之前的版本,自增主键最大值会在启动(重启)后从数据库中取出放到内存: SELECT MAX(ai_col) FROM table_name FOR UPDATE; 这样获取是通过计算的...如果删除最新一条数据(假设 ID 10),因故障或者其他必要重启后再插入一条数据时会使用之前的 ID (即 ID 10)。...从 MySQL 8.0 开始,自增主键最大值会在每次修改后写入到 redo log,并且在每个检查点写入引擎私有的系统表。 如果是正常重启,则读取系统表里的值。...其他 如果主动指定 ID 0 或者 NULL 插入,则会使用数据库生成的自增 ID。...参考文档 为什么 MySQL 的自增主键不单调也不连续 https://database.51cto.com/art/202004/614923.htm 《MySQL技术内幕——InnoDB存储引擎》

    10.8K10

    Mysql资料 主键

    表中的任何列都可以作为主键,只要它满足以下条件: 1、任何两行都不具有相同的主键值 2、每个行都必须具有一个主键值(主键列不允许NULL值) 除MySQL强制实施的规则外,应该坚持的几个普遍认为的最好习惯为...: 1、不更新主键列的值 2、不重用主键列的值 3、不在主键列中使用可能会更改的值(例如,如果使用一个名字作为主键以标识某个供应商,应该供应商合并和更改其名字时,必须更改这个主键) 总之:不应该使用一个具有意义的...column(id 本身并不保存表 有意义信息) 作为主键,并且一个表必须要有一个主键方便扩展、松耦合,高可用的系统做铺垫。...这就要求同一个叶子节点内(大小一个内存页或磁盘页)的各条数据记录按主键顺序存放,因此每当有一条新的记录插入时,MySQL会根据其主键将其插入适当的节点和位置,如果页面达到装载因子(InnoDB默认为15...如果没有显式地在表定义时指定主键,InnoDB存储引擎会为每一行生成一个6字节的ROWID,并一次作为主键mysql 在频繁的更新、删除操作,会产生碎片。而含碎片比较大的表,查询效率会降低。

    3.8K20

    mysql中清空表数据,并重置主键1

    MySQL中清空表数据,并重置主键1 ️ 摘要 在本文中,我将向大家展示如何在 MySQL 数据库中清空表的所有数据,并将主键重置 1。...这种情况下,仅仅删除数据是不够的,最好还能将主键(通常是自增的)重置 1。今天,我将向你们展示如何做到这一点。...命令的一个额外好处是,它会重置表的自增主键 1。...如果你想单独重置主键,可以使用 ALTER TABLE 语句,如下: ALTER TABLE table_name AUTO_INCREMENT = 1; 例如,要将 users 表的主键重置 1,你可以这样做...总结 清空 MySQL 表数据并重置主键 1 是一个非常简单但有用的操作,特别是在开发和测试阶段。通过使用 TRUNCATE TABLE 或 ALTER TABLE 语句,你可以轻松完成这个任务。

    43010

    mysql 取模分区_MySQL分区

    分区是将数据分段划分在多个位置存放,分区后,表面上还是一张表,但数据散列到多个位置了。app读写的时候操作的还是大表名字,db自动去组织分区的数据。...分区类型主要有range、list、hash、key 以常规hash举例说明分区是如何创建的 常规hash是取模运算 创建一个雇员表,根据id分成4个区,根据取模结果分别分成0,1,2,3四个区CREATE...` int(10) NOT NULL ) partition by hash (id) partitions 4; 创建成功之后查看数据文件,数据文件和索引文件单独存放 然后插入数据测试数据是否已经分区存在...按照预定的结果,id1应该放在分区1,2放在分区2,3放在分区3,4放在分区0 查看分区的分布情况SELECT PARTITION_NAME,PARTITION_METHOD,PARTITION_EXPRESSION...,然后查看数据如何存储 ALTER TABLE `partitions` COALESCE PARTITION 2 然后查看分布情况 发现数据重新取模存储到新的分区 发布者:全栈程序员栈长,转载请注明出处

    5K20

    mysql主键自增策略_MySQL 自增主键机制

    自增主键:特指在自增列上定义的主键。 自增主键的优点是让主键索引保持递增顺序的插入,避免页分裂,索引更加紧凑。 1. 自增值保存在哪? 不同的存储引擎保存自增值的策略不一样; a....Innodb引擎,mysql5.7之前,自增值保存在内存中,而且不会持久化自增值。...每次重启后第一次打开表,都会去查找自增值的最大值max(id), 并设置表当前自增值max(id) + 1; mysql8.0, 自增值变更记录在了redo log中,重启时依靠redo log恢复重启之前的值...指定了具体的值,若指定值小于当前自增值,则自增值不发生改变;若大于当前自增值,则自增值指定值+auto_increment_increment; 3. 自增值的修改时机? a....为了减少自增id锁带来的性能影响,mysql不会修改回去之前的自增值; 4. 自增锁的优化 a.

    9.4K50

    mysql分区函数_mysql 分区可用函数

    QUARTER() SECOND() TIME_TO_SEC() TO_DAYS() WEEKDAY() YEAR() YEARWEEK() 等 当然,还有FLOOR(),CEILING() 等,前提是使用这两个分区函数的分区必须是整型...分区应该和索引一样,一但where中出现函数,就会全区扫描 下面的表PARTITION BY LIST (month(create_time)),Explain结果不太乐观 mysql> Explain...如果空,没有可能的索引。可以为相关的域从WHERE语句中选择一个合适的语句 3 key:实际使用的索引。如果NULL,则没有使用索引。...在不损失精确性的情况下,长度越短越好 5 ref:显示索引的哪一列被使用了,如果可能的话,是一个常数 6 rows:MySQL认为必须检索的用来返回请求数据的行数 7 type:这是最重要的字段之一,显示查询使用了何种类型...如id=1; id 主键或唯一键. eq_ref:访问索引,返回某单一行的数据.(通常在联接时出现,查询使用的索引为主键或惟一键) ref:访问索引,返回某个值的数据.

    5.8K10

    mysql 分区 varchar_MySQL分区总结

    MySQL分区类型主要包括:range分区、list分区、hash分区、key分区; 无论是那种MySQL分区类型,要么分区表上没有主键/唯一键,要么分区表的主键/唯一键都必须包含分区键,也就是说不能使用主键...如: 去掉主键约束后,创建表会成功: 分区的名字遵循MySQL标识符的原则。分区的名字不区分大小写,如果分区名分别为 mypart 和 MyPart 将会被MySQL认为是同一个分区而报错。...p2;从p0 开始,模 0 时保存到 p0 依次类推。...分区支持使用 Blob 或 Text 类型外其他类型的列作为分区键 创建 Key 分区表的时候,可以不指定分区键,默认会首先选择使用主键作为分区键 在没有主键的情况,会选择非空唯一键作为分区键,分区键的唯一键必须是非空的...附:MySQL 分区的 null 值处理 1、MySQL 分区不禁止在分区键值上使用 null 2、Range 分区中,null 值会被当做最小值来处理 3、List 分区中,null 值必须出现在枚举列表中

    3.3K20

    MySQL表为什么必须主键 – 关于聚集索引的简介

    注意:下面讨论的都是MySQL5.6版本中的innodb引擎。 比较规范的数据库表设计(包括我们公司)都会有一条不成文的规定,那就是给每张表一个自增主键。...那么自增主键除了有数据的唯一性外,还有什么所用呢?为什么要有自增主键?...因此innodb也能理解基于索引的表。 * 那么Innodb如何决定那个索引作为聚集索引呢?* Innodb如何选择一个聚集索引 对于Innodb,主键毫无疑问是一个聚集索引。...请看如下规则 如果一个主键被定义了,那么这个主键就是作为聚集索引 如果没有主键被定义,那么该表的第一个唯一非空索引被作为聚集索引 如果没有主键也没有合适的唯一索引,那么innodb内部会生成一个隐藏的主键作为聚集索引...虽然遵循上面的原则也没错,但某些特殊的情况也是可以自己指定一些非自增主键聚集索引的。如: 当数据量大,但长时间不会被更新的; 新生成的数据的索引本来就是按照自增的顺序增加的等等。

    99710

    MySQL主键设计盘点

    主键设计和应用原则 除了满足MySQL强制实施的规则(主键不可重复;一行中主键不可为空)之外,主键的设计和应用应当还遵守以下公认的原则: 不更新主键列中的值; 不重用主键列的值; 不在主键列中使用可能会更改的值...(例如,如果使用一个 名字作为主键以标识某个供应商,当该供应商合并和更改其 名字时,必须更改这个主键。)...3、ID作为主键时在特定的环境会存在一些问题,比如需要排序的时候——UUID是无序的。 4、MySQL官方有明确的建议主键要尽量越短越好,36个字符长度的UUID不符合要求。...关于MySQL 使用自增ID主键和UUID 作为主键的性能比较可以查看参考【8】。 结论: 1、uuid做主键适用于小规模分布式架构用。...结论: 用自建的id生成器做主键适用于大规模分布式架构 参考: 【1】:红心李 :MySQL主键设计 【2】:Uncle Nucky :MySQL数据库主键设计原则 【3】:ellis:设计套路:Mysql

    4.2K30

    MySQL主键详解

    表中的任何列都可以作为主键,只要它满足以下主键值规则条件: 任两行不具相同的主键值 每行都必须具有一个主键值(主键列不允许NULL) 这里的规则是MySQL本身强制实施的。...除MySQL强制实施的规则外,还应该坚持的最佳实践: 不更新主键列中的值 不重用主键列的值 不在主键列中使用可能会更改的值 例如,如果使用一个名字作为主键以标识某个供应商,当该供应商合并和更改其 名字时...,必须更改这个主键) 联合主键 好处 可以直观的看到某个重复字段的记录条数 主键A跟主键B组成联合主键 主键A跟主键B的数据可以完全相同,联合就在于主键A跟主键B形成的联合主键是唯一的。...联合主键体现在多个表上,复合主键体现在一个表中的多个字段。 复合主键 主键通常定义在表的一列上,但这并不是必需的,也可使用多个列作为主键。...此时上述的条件必须应用到构成主键的所有列,所有列值的组合必须是唯一的(多列中的单个列的值可以不唯一)。

    4.9K20

    MySQL主键约束使用

    MySQL主键约束是一种用于确保表中每行数据的唯一性的限制。每个表只能有一个主键,它可以是一个或多个列。创建表时添加主键约束在创建表时添加主键约束,需要在列名后面添加关键字"PRIMARY KEY"。...这意味着在插入数据时,必须确保"id"列的值唯一,否则将会出现错误。在已经存在的表中添加主键约束如果已经存在一个表,但需要将某些列或字段添加主键约束,可以使用ALTER TABLE语句来修改表结构。...需要注意的是,在修改表结构时,必须将该列中已经存在的值都设置唯一,否则会出现错误。主键约束和自增列通常情况下,主键约束通常与自增列一起使用。自增列是指在插入新行时,自动该行分配一个唯一的值。...这意味着在插入数据时,无需提供"id"列的值,MySQL会自动其分配一个唯一的值。示例假设有一个用户表,其中包含以下列:id、name和email。...会自动其分配一个唯一的值。

    2.6K20

    mysql分区表_MySQL分区分表

    mysql中有一种机制是表锁定和行锁定,是为了保证数据的完整性。表锁定表示你们都不能对这张表进行操作,必须等我对表操作完才行。...分区和分表相似,都是按照规则分解表。不同在于分表将大表分解若干个独立的实体表,而分区是将数据分段划分在多个位置存放,分区后,表还是一张表,但数据散列到多个位置了。...举个简单例子:一个包含十年发票记录的表可以被分区十个不同的分区,每个分区包含的是其中一年的记录。...2)查看当前数据库是否支持分区 MySQL 5.6之前,使用下面的参数查看当前配置是否支持分区(如果yes则表示支持分区): mysql> SHOW VARIABLES LIKE ‘%partition...,一个是自己所需要的分区,最后一个分区还是maxvalue(也必须是maxvalue),这样就完成了添加分区

    10.8K20

    java mysql 分区表_mysql分区

    对用户来说,分区表是一个独立的逻辑表,但是底层由多个物理子表组成。实现分区的代码实际上是对一组底层表的句柄对象的封装。 mysql在创建表时使用PARTITION BY子句定义每个分区存放的数据。...在执行查询的时候,优化器会根据分区定义过滤那些没有我们需要数据的分区,这样查询就无须扫描所有分区——只需要查询包含需要数据的分区就可以了。...分区表本身也有一些限制,下面是其中比较重要的几点: 1.一个表最多只能有1024个分区。 2.在mysql5.1中,分区表达式必须是整数,或者是返回整数的表达式。...在mysql5.5中,某些场景中可以直接使用列进行分区。 3.如果分区字段中有主键或者唯一索引的列,那么所有主键列和唯一索引列都必须包含进来。 4.分区表中无法使用外键约束。...update操作 当更新一条记录时,分区层先打开并锁住所有的底层表,mysql先确定需要更新的记录在哪个分区,然后取出数据并更新,再判断更新后的数据在哪个分区,最后对底层进行写入操作,并对原数据所在的底层表进行删除操作

    7.8K10
    领券