mysql复合主键优缺点_MySQL中的复合主键性能缺陷
INSERT 和 UPDATE 性能变化很小: (INT) 和 (INT, INT) 键几乎相同 .SELECT 复合 PRIMARY KEY 的性能取决于很多因素 .如果您的表是 InnoDB ,则该表隐式聚类在 PRIMARY KEY 值上 .这意味着如果两个值都包含密钥,则对两个值的搜索将更快:不需要额外的密钥查找 .假设您的查询是这样的:SELECT*FROMmytableWH...
INSERT 和 UPDATE 性能变化很小: (INT) 和 (INT, INT) 键几乎相同 .
SELECT 复合 PRIMARY KEY 的性能取决于很多因素 .
如果您的表是 InnoDB ,则该表隐式聚类在 PRIMARY KEY 值上 .
这意味着如果两个值都包含密钥,则对两个值的搜索将更快:不需要额外的密钥查找 .
假设您的查询是这样的:
SELECT *
FROM mytable
WHERE col1 = @value1
AND col2 = @value2
表布局是这样的:
CREATE TABLE mytable (
col1 INT NOT NULL,
col2 INT NOT NULL,
data VARCHAR(200) NOT NULL,
PRIMARY KEY pk_mytable (col1, col2)
) ENGINE=InnoDB
,引擎只需要在表格中查找确切的键值 .
如果您使用autoincrement字段作为假id:
CREATE TABLE mytable (
id INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
col1 INT NOT NULL,
col2 INT NOT NULL,
data VARCHAR(200) NOT NULL,
UNIQUE KEY ix_mytable_col1_col2 (col1, col2)
) ENGINE=InnoDB
,然后引擎首先需要在索引 ix_mytable_col1_col2 中查找 (col1, col2) 的值,从索引中检索行指针( id 的值)并在表本身中通过 id 进行另一次查找 .
但是,对于 MyISAM 表,这没有区别,因为 MyISAM 表是堆组织的,而行指针只是文件偏移量 .
在这两种情况下,将创建相同的索引(对于 PRIMARY KEY 或 UNIQUE KEY ),并将以相同的方式使用 .
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)