扫码关注官方订阅号
该配置表的结构大致如下图:
每次需要取出UID为ming的所有行,UID列最多不超过50个相同项(即一个UID可能有多条配置),是否有建立索引的必要?如果有必要建立索引,该如何建立?
UID
ming
希望能给些建议,谢谢!
闭关修行中......
数据密度原则,数据密度是指列值唯一的记录占总记录数的百分比,这个比率越高,则说明此列越适合建立索引。反之,则不然。
经常作为查询条件的列,要考虑到建索引,提升查询速度。
对于大表而且使用频繁的表,在生产时最好不要去加索引; 如果对大表进行索引,取出的数据大于总量的5%至10%,使用索引扫描会效率下降很多。如果通过索引,取出数据量为总量的50%以上,这个时候还不如全表扫描来得快。数据量小的表,使用不频繁的不要单独另建立索引;
在查询条件中几个条件一起使用的,适合建立组合索引,否则不要建立组合索引,当单独引用非第一字段时将发生全表扫描;
在查询的时候,where条件不要对索引的列做处理,而要对后面的条件字段做处理。否则用不上这个列上的索引。
添加普通索引:ALTER TABLE table_name ADD INDEX index_name ( column )
table_name
column
添加主键索引:ALTER TABLE table_name ADD PRIMARY KEY ( column )
添加唯一索引:ALTER TABLE table_name ADD UNIQUE ( column )
添加全文索引:ALTER TABLE table_name ADD FULLTEXT ( column)
添加多列索引:ALTER TABLE table_name ADD INDEX index_name ( column1, column2, column3 )
column1
column2
column3
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
两个问题
建立索引的原则
数据密度原则,数据密度是指列值唯一的记录占总记录数的百分比,这个比率越高,则说明此列越适合建立索引。反之,则不然。
经常作为查询条件的列,要考虑到建索引,提升查询速度。
对于大表而且使用频繁的表,在生产时最好不要去加索引; 如果对大表进行索引,取出的数据大于总量的5%至10%,使用索引扫描会效率下降很多。如果通过索引,取出数据量为总量的50%以上,这个时候还不如全表扫描来得快。数据量小的表,使用不频繁的不要单独另建立索引;
在查询条件中几个条件一起使用的,适合建立组合索引,否则不要建立组合索引,当单独引用非第一字段时将发生全表扫描;
在查询的时候,where条件不要对索引的列做处理,而要对后面的条件字段做处理。否则用不上这个列上的索引。
如何建立索引
添加普通索引:ALTER TABLE
table_nameADD INDEX index_name (column)添加主键索引:ALTER TABLE
table_nameADD PRIMARY KEY (column)添加唯一索引:ALTER TABLE
table_nameADD UNIQUE (column)添加全文索引:ALTER TABLE
table_nameADD FULLTEXT (column)添加多列索引:ALTER TABLE
table_nameADD INDEX index_name (column1,column2,column3)结论
综上所述,您的这个需求不适合建立索引。