mysql 联合索引设计

联合索引又叫复合索引。对于复合索引:Mysql从左到右的使用索引中的字段,一个查询可以只使用索引中的一部份,但只能是最左侧部分。例如索引是key index (a,b,c). 可以支持a | a,b| a,b,c 3种组合进行查找,但不支持 b,c进行查找 .当最左侧字段是常量引用时,索引就十分有效。


索引原则

1.索引越少越好
原因:主要在修改数据时,第个索引都要进行更新,降低写速度。
2.最窄的字段放在键的左边
3.避免file sort排序,临时表和表扫描


疑惑:重复数据多的字段是否有必要建索引。

举例:

/* 评论表 */

CREATE TABLE `t_comment` (
  `CID` int(6) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `DYNAMIC_ID` varchar(6) DEFAULT NULL COMMENT '动态ID',
  `UID` varchar(6) DEFAULT NULL COMMENT '发布评论用户ID',
  `RID` varchar(6) DEFAULT NULL COMMENT '回复用户ID',
  `CONTENT` varchar(200) DEFAULT NULL COMMENT '评论内容',
  `CREATE_TIME` datetime DEFAULT NULL COMMENT '发布时间',
  `STATE` char(2) DEFAULT 0 COMMENT '评论状态0正常 1失效',
  PRIMARY KEY (`CID`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COMMENT='评论表';


建立 动态ID+用户ID+评论状态 联合索引

查询效率确实有所提高。

但是评论表update操作会很频繁,索引列多会导致索引重构变慢。

应尽量减少查询字段,将查询负担由缓存分担。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值