关于MySQL索引的好处,如果正确合理设计并且使用索引的MySQL是一辆兰博基尼的话,那么没有设计和使用索引的MySQL就是一个人力三轮车。对于没有索引的表,单表查询可能几十万数据就是瓶颈,而通常大型网站单日就可能会产生几十万甚至几百万的数据,没有索引查询会变的非常缓慢。还是以WordPress来说,其多个数据表都会对经常被查询的字段添加索引,比如wp_comments表中针对5个字段设计了BT            
                
         
            
            
            
            文章目录前言一、没有索引,可能会有什么问题二、认识磁盘MySQL与存储先来研究一下磁盘在看看磁盘中一个盘片扇区结论磁盘随机访问(Random Access)和连续访问(Sequential Access)三、MySQL与磁盘交互的基本单位四、建立共识五、索引的理解建立测试表插入多条记录查看插入结果中断一下---为何IO交互要是 Page理解单个Page理解多个Page页目录单页情况多页情况复盘一            
                
                    
                        
                                                            
                                                                        
                                                                                        原创
                                                                                    
                            2023-05-14 09:13:58
                            
                                185阅读
                            
                                                                             
                 
                
                                
                     
                                    
                             
         
            
            
            
            索引 定义 MySQL官方对索引(index)的定义是:索引是帮助MySQL高效获取数据的数据结构。 在数据库的应用中,索引可以简单理解成是一种排好序的快速查找数据结构。 常见索引: B树索引 B+树索引 哈希索引 优势与劣势 优势: 提高数据检索的效率,降低了数据库的IO成本。 降低了数据排序的成 ...            
                
                    
                        
                                                            
                                                                        
                                                                                        转载
                                                                                    
                            2021-09-27 15:54:00
                            
                                188阅读
                            
                                                                                    
                                2评论
                            
                                                 
                 
                
                             
         
            
            
            
            索引:提高数据库的性能,索引是物美价廉的东西了。不用加内存,不用改程序,不用调sql,只要执行正确的create index ,查询速度就可能提高成百上千倍。但是天下没有免费的午餐,查询速度的提高是以插入、更新、删除的速度为代价的,这些写操作,增加了大量的IO。所以它的价值,在于提高一个海量数据的检索速度。常见的索引分为:主键索引(primary key)唯一索引(unique)普通索引(inde            
                
                    
                        
                                                            
                                                                        
                                                                                        转载
                                                                                    
                            2024-04-17 11:33:34
                            
                                65阅读
                            
                                                                             
                 
                
                                
                     
                                    
                             
         
            
            
            
            文章目录一、初始索引二、MySQL与储存三、软件理解四、Page五、聚簇/非聚簇索引六、索引操作1.创建主键索引2.创建唯一索引3.创建普通索引4.查询索引5.删除索引一、初始索引索引的核心工作是提高数据库性能的,MySQL的服务器,本质是在内存中的,所有数据库的CURD操作,全部都是在内存中进行的 ...            
                
         
            
            
            
            # MySQL 主键索引的特性
在MySQL数据库中,主键索引是一种非常重要的索引类型,它具有以下几个特性:
1. **唯一性**:主键索引要求其中的值是唯一的,即表中的每一行数据在主键列上的取值都不相同。这样可以保证数据的完整性和准确性。
2. **自动增长**:主键索引通常与自动增长属性一起使用,这样可以确保每次插入新数据时主键值都是唯一的且递增的,简化了数据的维护和管理。
3. **            
                
                    
                        
                                                            
                                                                        
                                                                                        原创
                                                                                    
                            2024-03-28 05:37:59
                            
                                70阅读
                            
                                                                             
                 
                
                             
         
            
            
            
            函数索引顾名思义就是加给字段加了函数的索引,这里的函数也可以是表达式。所以也叫表达式索引。MySQL 5.7 推出了虚拟列的功能,MySQL8.0的函数索引内部其实也是依据虚拟列来实现的。我们考虑以下几种场景:1.对比日期部分的过滤条件。SELECT ...FROM tb1WHERE date(time_field1) = current_date;2.两字段做计算。SELECT ...FROM             
                
                    
                        
                                                            
                                                                        
                                                                                        原创
                                                                                    
                            2021-01-26 10:16:29
                            
                                183阅读
                            
                                                                             
                 
                
                             
         
            
            
            
            作者:杨涛涛函数索引顾名思义就是加给字段加了函数的索引,这里的函tb1WHERE date(time_field1) = current_date;...            
                
                    
                        
                                                            
                                                                        
                                                                                        原创
                                                                                    
                            2022-12-20 14:40:03
                            
                                149阅读
                            
                                                                             
                 
                
                                
                     
                                    
                             
         
            
            
            
            我们今天来介绍下 MySQL 8.0 引入的新特性:倒序索引。MySQL长期以来对索引的建立只允许正向asc存储,就算建立了desc,也是忽略掉。比如对于以下的查询,无法发挥索引的最佳性能。查询一:select * from tb1 where f1 = ... order by id desc;查询二:2. select * from tb1 where f1 = ... order by f1            
                
                    
                        
                                                            
                                                                        
                                                                                        原创
                                                                                    
                            2021-01-25 17:57:54
                            
                                1872阅读
                            
                                                                             
                 
                
                             
         
            
            
            
            作者:杨涛涛我们今天来介绍下 MySQL 8.0 引入的新特性:倒序索引。MySQL长期以来对索引的建立只允许正向asc存储,就算建立了desc,也是忽略掉。比如对于以下的查询,无法发挥索引的最佳性能。	查询一:	select * from tb1 where f1 = ... orde            
                
                    
                        
                                                            
                                                                        
                                                                                        原创
                                                                                    
                            2022-12-20 14:40:43
                            
                                707阅读
                            
                                                                             
                 
                
                                
                     
                                    
                             
         
            
            
            
            文章目录MySQL索引特性索引的概念认识磁盘磁盘的结构磁盘的随机访问(Random Access)与连续访问(Sequential Access)MySQL与磁盘交互的基本单位索引的理解观察主键索引现象推导主键索引结构的构建索引结构可以采用哪些数据结构聚簇索引 VS 非聚簇索引索引操作创建主键索引创建唯一索引创建普通索引创建全文索引查询索引删除索引索引创建原则 MySQL索引特性索引的概念索引的            
                
                    
                        
                                                            
                                                                        
                                                                                        转载
                                                                                    
                            2024-01-19 22:41:18
                            
                                42阅读
                            
                                                                             
                 
                
                                
                     
                                    
                             
         
            
            
            
            作者:杨涛涛MySQL 8.0 实现了索引的隐藏属性。当然这个特性很多            
                
                    
                        
                                                            
                                                                        
                                                                                        原创
                                                                                    
                            2022-12-20 14:40:21
                            
                                156阅读
                            
                                                                             
                 
                
                             
         
            
            
            
            MySQL 8.0 实现了Index skip scan,翻译过来就是索引跳跃扫描。熟悉ORACLE的朋友是不是发现越来越像ORACLE了?再者,熟悉MySQL 5.7 的朋友是不是觉得这个很类似当时优化器的选项MRR?好了,先具体说下什么 ISS,我后面全部用 ISS 简称。*考虑以下的场景:表t1有一个联合索引idx_u1(rank1,rank2),但是查询的时候却没有rank1这列,只有ra            
                
                    
                        
                                                            
                                                                        
                                                                                        原创
                                                                                    
                            2021-01-26 10:15:24
                            
                                524阅读
                            
                                                                             
                 
                
                             
         
            
            
            
            作者:杨涛涛MySQL 8.0 实现了Index skip scan,翻译过来就是索引跳跃扫描。熟悉O            
                
                    
                        
                                                            
                                                                        
                                                                                        原创
                                                                                    
                            2022-12-20 15:13:58
                            
                                712阅读
                            
                                                                             
                 
                
                                
                     
                                    
                             
         
            
            
            
            数据库索引:索引的概念:索引是数据库表中一列或多列的值进行排序的一种结构,使用索引可快速访问数据库表中的特定信息。如果想按特定职员的性查找他或她,则与在表中搜索的所有行相比,索引有助于更快的获取信息。 索引的一个主要的目的就是加快检索表中数据的方法,也是尽快的找到符合限制条件的记录ID的辅助数据结构优点:通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。可以大大加快数据的检索速度,这也是创            
                
                    
                        
                                                            
                                                                        
                                                                                        转载
                                                                                    
                            2024-05-29 12:38:19
                            
                                15阅读
                            
                                                                             
                 
                
                             
         
            
            
            
            持降序索引 在MySQL5.7和MySQL8.0中创建表 CREATE TABLE ts1(a int,b int,index idx_a            
                
                    
                        
                                                            
                                                                        
                                                                                        原创
                                                                                    
                            2022-10-02 00:01:56
                            
                                86阅读
                            
                                                                             
                 
                
                             
         
            
            
            
            【MySQL 8.0】新特性:函数索引            
                
                    
                        
                                                            
                                                                        
                                                                                        原创
                                                                                    
                            2023-08-27 10:44:23
                            
                                129阅读
                            
                                                                             
                 
                
                             
         
            
            
            
            mysql 8.0高级特性,优化,索引 文章目录 ?3.Mysql高级篇 3.1 MySQL架构篇(P96~P114) 3.1.1 基本概念 3.1.1.1 查看字符集 3.1.1.2 字符集与比较规则 3.1.2 SQL规范与SQL_Mode 3.1.2.1 基本概念 3.1.2.1 SQL_M            
                
                    
                        
                                                            
                                                                        
                                                                                        原创
                                                                                    
                            2023-03-26 05:14:22
                            
                                334阅读
                            
                                                                             
                 
                
                                
                     
                                    
                             
         
            
            
            
            MySQL 8.0终于支持降序索引了。其实,从语法上,MySQL 4就支持了,但正如官方文档所言,"they are pars            
                
                    
                        
                                                            
                                                                        
                                                                                        转载
                                                                                    
                            2022-06-01 06:48:31
                            
                                789阅读
                            
                                                                             
                 
                
                                
                     
                                    
                             
         
            
            
            
            我们有时候想删除掉冗余索引,但是又怕删除之后影响到查询性能,这时候再回退就需要一定的时间。MySQL8.0开始支持隐藏索引(invisibleindexes),隐藏索引不会被优化器使用,如果你想验证某个索引删除之后的查询性能影响,就可以暂时先隐藏该索引。但是有一点主键不能被设置为隐藏索引,当表中没有显式主键时,表中第一个唯一非空索引会成为隐式主键,也不能设置为隐藏索引。索引默认是可见的,在使用CR            
                
                    
                        
                                                            
                                                                        
                                                                                        原创
                                                                                    
                            2020-11-30 14:45:29
                            
                                363阅读