首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql 建表联合索引

基础概念

MySQL中的联合索引(也称为复合索引或多列索引)是指在多个列上创建的索引。联合索引可以显著提高多条件查询的性能,因为它允许数据库引擎在一个索引中同时查找多个列的值。

优势

  1. 提高查询效率:对于多条件查询,联合索引可以减少数据库引擎需要扫描的数据量,从而提高查询速度。
  2. 减少磁盘I/O操作:通过联合索引,数据库引擎可以更快地定位到所需的数据行,减少磁盘I/O操作。
  3. 优化排序和分组:如果查询涉及到多个列的排序或分组,联合索引可以提供更好的性能。

类型

MySQL中的联合索引主要有以下几种类型:

  1. 普通索引:最基本的索引类型,没有特殊限制。
  2. 唯一索引:索引列的值必须唯一,但允许有空值。
  3. 主键索引:主键列上的索引,主键列的值必须唯一且非空。
  4. 全文索引:用于全文搜索的索引,适用于文本数据。

应用场景

联合索引适用于以下场景:

  1. 多条件查询:当查询条件涉及多个列时,使用联合索引可以提高查询效率。
  2. 排序和分组:当查询需要对多个列进行排序或分组时,联合索引可以提供更好的性能。
  3. 覆盖索引:当查询的所有列都在索引中时,可以避免回表查询,提高查询效率。

示例代码

假设有一个用户表 users,包含以下列:idnameagecity。现在需要创建一个联合索引,以提高基于 namecity 的查询效率。

代码语言:txt
复制
CREATE TABLE users (
    id INT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(50),
    age INT,
    city VARCHAR(50)
);

CREATE INDEX idx_name_city ON users(name, city);

遇到的问题及解决方法

问题1:为什么联合索引不按预期提高查询效率?

原因

  1. 查询条件顺序不匹配:联合索引的顺序很重要,查询条件必须按照索引列的顺序来使用。
  2. 数据分布不均匀:如果索引列的数据分布不均匀,可能会导致索引效果不佳。
  3. 查询条件使用了函数或计算:如果查询条件中使用了函数或计算,可能会导致索引失效。

解决方法

  1. 调整查询条件顺序:确保查询条件按照索引列的顺序来使用。
  2. 优化数据分布:通过数据分区和分表等方式优化数据分布。
  3. 避免使用函数或计算:尽量避免在查询条件中使用函数或计算。

问题2:如何选择联合索引的列?

解决方法

  1. 分析查询模式:根据实际的查询模式,选择最常用的查询条件列。
  2. 考虑选择性:选择具有较高选择性的列,即列中不同值的数量较多。
  3. 避免过度索引:过多的索引会增加写操作的开销,并占用更多的存储空间。

参考链接

MySQL联合索引详解

MySQL索引优化

希望以上信息对你有所帮助!

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

mysql建立联合索引_mysql联合索引

mysql联合索引测试: 前期准备: 建立联合索引?...,则该索引仅出现在key列表中 rows: 根据统计信息及索引选用情况,大致估算出找到所需的记录所需要读取的行数 Extra: 1、Using filesort : mysql对数据使用一个外部的索引排序...也就是说mysql无法利用索引完成的排序操作成为“文件排序” 2、Using temporary: 使用临时保存中间结果,也就是说mysql在对查询结果排序时使用了临时,常见于order by 和...当type出现all时,表示走的是全扫描没有走索引,效率低下,这时需要对sql进行调优。...测试语句是否使用了索引: 网上说联合索引 test_col1_col2_col3 实际建立了(col1)、(col1,col2)、(col,col2,col3)三个索引

5K30

MySQL联合索引or_MySQL联合索引命中条件

.* FROM E WHERE E.e1=1 AND E.e3=2”涉及到两列,这个时候我们一般采用一个联合索引(e1, e3);而不用两个单列索引,这是因为一条查询语句往往应为mysql优化器的关系只用一个索引...,就算你有两个索引,他也只用一个;在只用一个的基础之上,联合索引是会比单列索引要快的; 下面讲讲联合索引的使用规则和哪些情况会命中不了联合索引 示例如下。...首先创建: CREATE TABLE E (e1 INT, e2 VARCHAR(9), e3 INT, PRIMARY KEY(e1, e3)); 这样就建立了一个联合索引:e1,e3 测试数据 INSERT...INTO E (e1, e2, e3) VALUES(1, ‘aa’, 2); 触发联合索引是有条件的: 1、使用联合索引的全部索引键,可触发索引的使用。....* FROM E WHERE E.e3=1 4、使用联合索引的全部索引键,但索引键不是AND操作,不可触发索引的使用。

1.9K30
  • MySQL 联合索引

    1.简介 联合索引指建立在多个列上的索引MySQL 可以创建联合索引(即多列上的索引)。一个索引最多可以包含 16 列。...联合索引可以测试包含索引中所有列的查询,或仅测试第一列、前两列、前三列等等的查询。如果在索引定义中以正确的顺序指定列,则复合索引可以加快对同一的多种查询的速度。 下面是一个联合索引的例子。...(4)如果 SQL 为: SELECT * FROM table WHERE a = 1 ORDER BY b; 对 (a,b) 索引,当 a = 1 的时候,b 相对有序,可以避免再次排序。...联合索引有一个作用就是实现覆盖索引,如果联合索引包含了查询所需的所有列,那么查询可以直接从索引中获取所需的数据,避免了额外的访问,这可以减少 I/O 操作,提高查询性能。...参考文献 8.3.1 How MySQL Uses Indexes - MySQL 8.3.6 Multiple-Column Indexes - MySQL 面试官:谈谈你对mysql联合索引的认识

    23220

    mysql 联合索引 唯一_mysql 联合索引和唯一索引

    如果也有DML, 我一般只在a 上索引. 这也是代价平衡的结果....一方面 只在a 上索引那么是 index range scan, 不像联合索引那样可以index unique scan , 我觉得速度差的不多(数据量不大的情况)....所以我一般采取折中.只单列或2列索引. 联合索引对于查询 where a=? and b=? and c=? 这样的语句时,速度比分开的索引要快很多!...索引怎么建立,除了你的程序应用,还应当要考虑到的活动是否频繁, 如果是典型的oltp,索引就不要建立太多,位图索引就不用考虑, 但是dss系统,主要是为了检索,索引多一点就无所谓 联合索引使用结论:...本文主旨:讨论什么情况下能利用上索引. 索引:创建索引可以根据查询业务的不同分为两种:单一列的索引,联合索引. 顾名思义,单一列索引就是指在的某一列上创建索引,联合索引是在多个列上联合创建索引.

    2.7K20

    mysql联合索引abc 使用bac_mysql 联合索引

    mysql 联合索引详解 联合索引又叫复合索引。对于复合索引:Mysql从左到右的使用索引中的字段,一个查询可以只使用索引中的一部份,但只能是最左侧部分。...两个或更多个列上的索引被称作复合索引。利用索引中的附加列,您可以缩小搜索的范围,但使用一个具有两列的索引 不同于使用两个单独的索引。...2.最窄的字段放在键的左边 3.避免file sort排序,临时扫描....创建CREATE TABLE IF NOT EXISTS `tbl_test` (`id` int(11) NOT NULL AUTO_INCREMENT,`a` varchar(15) NOT NULL...,bc,cb算是同一种查询,都用不到索引2、以a开头的查询都可以用到索引,a,ab,abc3、不以a开头的用不到索引,b,c,bc,因此在建索引的时候应该将最常用的字段放到第一位,这样才能最大程度的使用联合索引

    1.7K40

    mysql联合索引详解

    比较简单的是单列索引(b+tree)。遇到多条件查询时,不可避免会使用到多列索引联合索引又叫复合索引。...b+tree结构如下: 每一个磁盘块在mysql中是一个页,页大小是固定的,mysql innodb的默认的页大小是16k,每个索引会分配在页上的数量是由字段的大小决定。...创建test如下: create table test( a int, b int, c int, KEY a(a,b,c)); 比如(a,b,c)的时候,b+数是按照从左到右的顺序来建立搜索树的...以下通过例子分析索引的使用情况,以便于更好的理解联合索引的查询方式和使用范围。 一、多列索引在and查询中应用 select * from test where a=? and b=?...四,总结联合索引的使用在写where条件的顺序无关,mysql查询分析会进行优化而使用索引。但是减轻查询分析器的压力,最好和索引的从左到右的顺序一致。使用等值查询,多列同时查询,索引会一直传递并生效。

    1.2K20

    mysql联合索引详解

    上一篇文章:mysql数据库索引优化 比较简单的是单列索引(b+tree)。遇到多条件查询时,不可避免会使用到多列索引联合索引又叫复合索引。...b+tree结构如下: 每一个磁盘块在mysql中是一个页,页大小是固定的,mysql innodb的默认的页大小是16k,每个索引会分配在页上的数量是由字段的大小决定。...创建test如下: create table test( a int, b int, c int, KEY a(a,b,c) ); 比如(a,b,c)的时候,b+数是按照从左到右的顺序来建立搜索树的,...以下通过例子分析索引的使用情况,以便于更好的理解联合索引的查询方式和使用范围。 一、多列索引在and查询中应用 select * from test where a=? and b=? and c=?...四,总结 联合索引的使用在写where条件的顺序无关,mysql查询分析会进行优化而使用索引。但是减轻查询分析器的压力,最好和索引的从左到右的顺序一致。

    8.9K90

    mysql联合索引有什么好处_联合索引和单个索引

    因为InnoDB的数据文件本身要按主键聚集,所以InnoDB要求必须有主键(MyISAM可以没有),如果没有显式指定,则MySQL系统会自动选择一个可以唯一标识数据记录的列作为主键,如果不存在这种列,...则MySQL自动为InnoDB生成一个隐含字段作为主键,这个字段长度为6个字节,类型为长整形。...3.1 联合索引 联合索引顾名思义就是多个列组成的索引,比如,以具体数据来看,查看数据索引: SHOW INDEX FROM pre_sales_rfq 通过输出结果可以看出...,pre_sales_rfq有2个索引:主键索引(id)、联合索引(project_id,item_id)。...3.2 索引选择性与前缀索引 首先不是任何时候都必须索引,一般数据量较少(千级别)的数据没必要索引,全查询即可,因为索引文件本身要消耗存储空间,同时索引会加重插入、删除和修改记录时的负担,另外,

    2.1K10

    MySQL索引需要的原则

    2.为经常需要排序、分组和联合操作的字段建立索引 经常需要ORDER BY、GROUP BY、DISTINCT和UNION等操作的字段,排序操作会浪费很多时间。...因此,为这样的字段建立索引,可以提高整个的查询速度。 4.限制索引的数目 索引的数目不是越多越好。每个索引都需要占用磁盘空间,索引越多,需要的磁盘空间就越大。修改时,对索引的重构和更新很麻烦。...越多的索引,会使更新变得很浪费时间。 5.尽量使用数据量少的索引 如果索引的值很长,那么查询的速度会受到影响。...mysql会一直向右匹配直到遇到范围查询(>、 3 and d = 4 如果建立(a,b,c,d)顺序的索引...比如a = 1 and b = 2 and c = 3 建立(a,b,c)索引可以任意顺序,mysql的查询优化器会帮你优化成索引可以识别的形式 10.尽量选择区分度高的列作为索引

    1.7K20

    mysql联合索引的理解

    /q/1010000003984016/a-1020000003984281 联合索引又叫复合索引。...http://blog.csdn.net/lmh12506/article/details/8879916 当一个有多条索引可走时, Mysql 根据查询语句的成本来选择走哪条索引, 联合索引的话...基数根据被存储为整数的统计数据来计数,所以即使对于小型,该值也没有必要是精确的。基数越大,当进行联合时,MySQL使用该索引的机会就越大。   ...zl_yhjbqk group by qc_bh 什么情况下应不或少索引 表记录太少 如果一个只有5条记录,采用索引去访问记录的话,那首先需访问索引,再通过索引访问数据,一般索引与数据不在同一个数据块...如表zl_sybm(使用部门)一般只有几条记录,除了主关键字外对任何一个字段索引都不会产生性能优化,实际上如果对这个进行了统计分析后ORACLE也不会用你索引,而是自动执行全访问。

    1.5K20

    【推荐】mysql联合 索引(复合索引)的探讨

    Mysql联合 索引(复合索引)的使用原则 命名规则:名_字段名 需要加索引的字段,要在where条件中。 数据量少的字段不需要加索引。最窄的字段放在键的左边。...下面用例子来说明多列联合索引的用法。...什么情况下应不或少索引 表记录太少 如果一个只有5条记录,采用索引去访问记录的话,那首先需访问索引,再通过索引访问数据,一般索引与数据不在同一个数据块,这种情况下ORACLE至少要往返读取数据块两次...如表zl_sybm(使用部门)一般只有几条记录,除了主关键字外对任何一个字段索引都不会产生性能优化,实际上如果对这个进行了统计分析后ORACLE也不会用你索引,而是自动执行全访问。...数据重复且分布平均的表字段 假如一个有10万行记录,有一个字段A只有T和F两种值,且每个值的分布概率大约为50%,那么对这种A字段索引一般不会提高数据库的查询速度。

    3K20

    mysql索引多了有什么坏处

    建立索引常用的规则如下: 1、的主键、外键必须有索引; 2、数据量超过300的应该有索引; 3、经常与其他进行连接的,在连接字段上应该建立索引; 4、经常出现在Where子句中的字段,特别是大的字段...,应该建立索引; 5、索引应该建在选择性高的字段上; 6、索引应该建在小字段上,对于大的文本字段甚至超长字段,不要索引; 7、复合索引的建立需要进行仔细分析;尽量考虑用单字段索引代替:  A、正确选择复合索引中的主列字段...,考虑减少复合的字段;  C、如果复合索引中包含的字段经常单独出现在Where子句中,则分解为多个单字段索引; 进行数据操作的,不要建立太多的索引; 9、删除无用的索引,避免对执行计划造成负面影响...因为太多的索引与不充分、不正确的索引对性能都毫无益处:在上建立的每个索引都会增加存储开销,索引对于插入、删除、更新操作也会增加处理上的开销。...另外,过多的复合索引,在有单字段索引的情况下,一般都是没有存在价值的;相反,还会降低数据增加删除时的性能,特别是对频繁更新的来说,负面影响更大 发布者:全栈程序员栈长,转载请注明出处:https://

    2.8K20

    粗聊Mysql——你会么?

    本文中说到的“”,并非单纯的一个库,或是一张,而是你建好的库和在项目的运营中,是否能应付各种事件,下面我说说几个我在项目中遇到的问题以及处理的方法,算是一个小小的心得,给大家分享下。...比如现在有2张,一张新闻栏目,一张新闻,现在两张需要进行关联,我想大多数人的做法肯定是在新闻表里一个新闻栏目id,然后把新闻栏目表里的主键ID(自增)写到这个字段里,通过这样进行两关联。   ...所以我建议两之间关联不用主键,而是单独一个编号的字段,我们这里可以用mysql的uuid()函数做为编号,相关文献可以参考《UUID做主键好还是不好》,只所以一张要2个主键,一个物理主键(自增id...至于性能,我本地测了下基本上没差异,网上也有人做了10W条数据的测试——《实测MYSQL UUID性能》。...四、为常用的搜索字段建立索引吧   不解释,但不要盲目建立索引。 五、欢迎您的回复补充

    5.2K10

    mysql联合索引的使用规则

    从一道有趣的题目开始分析: 假设某个有一个联合索引(c1,c2,c3,c4)以下选项哪些字段使用了该索引: A where c1=x and c2=x and c4>x and c3=x B where...1’),(‘2′,’2′,’2′,’2′,’2’) 使用MySql Explain开始分析题目结果: A选项: 结果可以看出,c1,c2,c3,c4均使用到了该索引,而我们对A结果稍作更改: 将c2...下面2图我们对比下索引最左原则: 上图结果显示直接使用c3是全查询,无法使用该索引的,所以c3字段使用索引的前提是c1,c2两字段均使用了索引。 即是索引的最左原则(左前缀原则)。...排序其实是利用联合索引直接完成了的,即:使用了c1234联合索引,就已经使得c1下c2,c2下c3,c3下c4是有序的了,所以实际是排序利用了索引,c3字段并没有使用该索引。...c1,c2,c3,c4….cN)的联合索引,where 条件按照索引建立的字段顺序来使用(不代表and条件必须按照顺序来写),如果中间某列没有条件,或使用like会导致后面的列不能使用索引

    1.4K20

    mysql查询索引_MySQL查看表索引

    mysql> show index from tblname; mysql> show keys from tblname; · Table 的名称。...· Non_unique 如果索引不能包括重复词,则为0。如果可以,则为1。 · Key_name 索引的名称。 · Seq_in_index 索引中的列序列号,从1开始。...· Collation 列以什么方式存储在索引中。在MySQL中,有值‘A’(升序)或NULL(无分类)。 · Cardinality 索引中唯一值的数目的估计值。...基数根据被存储为整数的统计数据来计数,所以即使对于小型,该值也没有必要是精确的。基数越大,当进行联合时,MySQL使用该索引的机 会就越大。...· Sub_part 如果列只是被部分地编入索引,则为被编入索引的字符的数目。如果整列被编入索引,则为NULL。 · Packed 指示关键字如何被压缩。如果没有被压缩,则为NULL。

    6.8K40

    MySQL 系列教程之(五)DDL 操作:

    创建RUNOOB数据库,并设定编码集为utf8 删除数据库 删库有风险,动手需谨慎 drop database 库名; MySQL 数据 创建MySQL数据需要以下信息: 名 表字段名 定义每个表字段...MySQL数据。...查看表结构 desc stu; 查看表语句 show create table stu\G 修改结构 格式: alter table 名 action(更改选项); 添加字段: 添加字段:alter...中的name字段添加唯一性索引索引名为uni_name; alter table user add unique uni_name(name); -- 为user中的email字段添加普通索引...删除 MySQL中删除数据是非常容易操作的, 但是你再进行删除操作时要非常小心,因为执行删除命令后所有数据都会消失。 DROP TABLE table_name ;

    7.7K73
    领券