联合索引又叫复合索引。对于复合索引: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操作会很频繁,索引列多会导致索引重构变慢。
应尽量减少查询字段,将查询负担由缓存分担。