那么,怎么合理地建立索引呢?这里分享一下我的一些经验,如有不妥之处 , 欢迎批评指正 。
1、不要盲目建立索引,先分析再创建
索引虽然能大幅度提升我们的查询性能,但也要知道,在你进行增删改时,索引树也要同样地进行维护 。所以,索引不是越多越好,而是按需建立 。最好是在一整块模块开发完成后,分析一下,去针对大多数的查询,建立联合索引 。
2、使用联合索引尽量覆盖多的条件
这是说在一个慢sql里假如有五个where ,一个 order by , 那么我们的联合索引尽量覆盖到这五个查询条件,如果有必要,order by 也覆盖上。
3、小基数字段不需要索引
这个意思是,如果一张表里某个字段的值只有那么几个 , 那么你针对这个字段建立的索引其实没什么意义,比如说,一个性别字段就两种结果 , 你建了索引,排序也没什么意思(也就是索引里把男女给分开了)
所以说,索引尽量选择基数大的数据去建立 , 能最大化地利用索引
4、长字符串可以使用前缀索引
我们建立索引的字段尽量选择字段类型较小的,比如一个varchar(20)和varchar(256)的,我们在20的上面建立的索引和在256上就有明显的差距(字符串那么长排序也不好排呀,唉) 。
当然,如果一定是要对varchar(256)建立索引,我们可以选择里面的前20个字符放在索引树里(这里的20不绝对,选择能尽量分辨数据的最小字符字段设计),类似这样KEY index(name(20),age,job) ,索引只会对name的前20个字符进行搜索 , 但前缀索引无法适用于order by 和 group by 。
5、对排序字段设计索引的优先级低
如果一个SQL里我们出现了范围查找,后边又跟着一个排序字段,那么我们优先给范围查找的字段设置索引,而不是优先排序 。
6、如果出现慢SQL , 可以设计一个只针对该条SQL的联合索引 。
【mysql索引怎么建 mysql怎么建立索引】不过慢SQL的优化,需要一步步去进行分析 , 可以先用explain查看SQL语句的分析结果 , 再针对结果去做相应的改进 。explain的东西我们下次再讲 。
PS:在 select 语句之前增加 explain 关键字 , MySQL 会在查询上设置一个标记,执行查询会返回执行计划的信息 , 而不是 执行这条SQL 。
MySQL中如何设置唯一索引,联合索引?1.UNIQUE 关键字建唯一索引\x0d\x0amysql CREATE TABLE `wb_blog` (\x0d\x0a-`id` smallint(8) unsigned NOT NULL,\x0d\x0a-`catid` smallint(5) unsigned NOT NULL DEFAULT '0',\x0d\x0a-`title` varchar(80) NOT NULL DEFAULT '',\x0d\x0a-`content` text NOT NULL,\x0d\x0a-PRIMARY KEY (`id`),\x0d\x0a-UNIQUE KEY `catename` (`catid`)\x0d\x0a- ) ;\x0d\x0a如果建好表了,可以用以下语句建\x0d\x0a mysql CREATE UNIQUE INDEX catename ON wb_blog(catid);\x0d\x0a\x0d\x0a2.联合索引\x0d\x0aALTER TABLE `tasks`\x0d\x0aADD INDEX `testabc` (`title`, `created`) ;\x0d\x0a\x0d\x0a3联合唯一索引(假设有这个需求,在同一天内不能建两个tiltle一样的任务)\x0d\x0aALTER TABLE `tasks`\x0d\x0aADD UNIQUE INDEX `testabc` (`title`, `created`) ;\x0d\x0a\x0d\x0a数据库建索引的科学性事关数据库性能,索引也不是越多越好 。
mysql索引怎么建的介绍就聊到这里吧 , 感谢你花时间阅读本站内容,更多关于mysql怎么建立索引、mysql索引怎么建的信息别忘了在本站进行查找喔 。
推荐阅读
- 都有些什么症状视频,一般都有什么症状
- 老手机照片怎么全部删除,老手机里的照片怎么搞出来
- linux安装oracle集群,linux oracle安装步骤详细
- 浩方的服务器,浩方电竞平台服务器连不上
- linux目录比较命令 linux 比较目录
- 快手为什么没有直播,快手为什么没有直播功能
- 游戏里面的乐高赛车怎么拼,用乐高拼赛车怎么拼
- 视频号怎么查粉丝属性标签,视频号如何查看粉丝
- vb.net运行中的图片 vb加载图片路径