MySQL 索引和连接的介绍和使用

目录

建索引的原则

索引覆盖

索引失效

左连接 内连接 右连接的区别


建索引的原则

字段没有大量相同取值,区分性好,比如身份证号优于性别。

字段占用空间小。

考虑使用索引覆盖。对数据很少被更新的表,如果用户经常只查询其中的几个字段,可以考虑在这几个字段上建立索引,从而将表的扫描改变为索引的扫描。

除了以上原则,在创建索引时,我们还应当注意以下的限制:

(1)限制表上的索引数目。

对一个存在大量更新操作的表,所建索引的数目一般不要超过3个,最多不要超过5个。索引虽说提高了访问速度,但太多索引会影响数据的更新操作。

(2)不要在有大量相同取值的字段上,建立索引。

在这样的字段(例如:性别)上建立索引,字段作为选择条件时将返回大量满足条件的记录,优化器不会使用该索引作为访问路径。

索引覆盖

假如有这样一张表:

CREATE TABLE `test` (
  `id` int(11) NOT NULL,
  `age` int(11) NOT NULL,
  `name` varchar(255) NOT NULL DEFAULT '',
  PRIMARY KEY (`id`),
  KEY `idx_age_name` (`age`,`name`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

两种查询语句

SELECT * FROM test WHERE age = 10;
SELECT age,NAME FROM test WHERE age = 10;

 下面的这个走的是覆盖索引,比上面的快,是因为下面这个没有回表的操作,所以速度更快。

在实际应用中,如果select 多个字段比较慢的话,可以尝试将这多个字段建立联合索引,这样只需要扫描一遍联合索引树即可得到数据。

索引失效

MySQL 索引失效的几种类型以及解决方式 - 知乎

索引列不独立是指 被索引的这列不能是表达式的一部分,不能是函数的参数,比如下面的这种情况

select id,name,age,salary from table_name where salary + 1000 = 6000;

salary 列被用户表达式的计算了,这种情况下索引就会失效,解决方式就是提前计算好条件值,不要让索引列参与表达式计算,修改后 sql 如下

select id,name,age,salary from table_name where salary = 5000;

索引字段作为函数的参数

select id,name,age,salary from table_name where substring(name,1,3)= 'luc';

解决方式是什么呢,可以提前计算好条件,不要使用索引,或者可以使用其他的 sql 替换上面的,比如,上面的sql 可以使用 like 来代替

select id,name,age,salary from table_name where name like 'luc%';

使用了左模糊

select id,name,age,salary from table_name where name like '%lucs%';

平时尽可能避免用到左模糊,可以这样写

select id,name,age,salary from table_name where name like 'lucs%';

如果实在避免不了左模糊查询的话,考虑一下搜索引擎 比如 ES

不符合最左前缀原则的查询

例如有这样一个组合索引 index(a,b,c)

select * from table_name where b='1'and c='2'
select * from table_name where c='2'

// 上面这两条 SQL 都是无法走索引执行的

最左原则,就是要最左边的优先存在。

查询的数量是大表的大部分,全表扫描比走索引更快。

左连接 内连接 右连接的区别

左连接,右连接,全外连接的区别是什么? - 知乎

为什么要用连接(join)

因为大部分情况下,要符合数据库设计规范,数据不可能集中在同一张表里,那样的话会产生数据冗余,但是分成多张表会造成取数比较麻烦,join(连接)就是为解决上述问题的一种语法。

left join (左连接):返回包括左表中的所有记录和右表中连接字段相等的记录,右表没有就填充为null;

right join (右连接):返回包括右表中的所有记录和左表中连接字段相等的记录,左表没有就填充为null;

inner join (等值连接或者叫内连接):只返回两个表中连接字段相等的行,两边都有才返回。

full join (全外连接):返回左右表中所有的记录和左右表中连接字段相等的记录。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
引用\[1\]中提到了mysql索引的作用、创建规则、问题、创建方法、类型、删除方法和注意事项。引用\[2\]中给出了创建索引的语法示例。引用\[3\]中提到了建立复合索引的情况。综合这些内容,可以回答问题。 回答: 在MySQL中,索引是一种用于提高查询效率的数据结构。它可以加快数据的查找速度,减少数据库的IO操作。创建索引的规则包括在创建表时使用CREATE TABLE语句创建索引使用CREATE INDEX语句单独为表增加索引使用ALTER TABLE语句为表增加索引等方法。\[1\]例如,可以使用以下语法创建一个名为st_name的索引:CREATE TABLE student (Sno char(5), Sname varchar(20) not null, INDEX st_name (Sname));\[2\]此外,为了进一步提高MySQL的效率,可以考虑建立复合索引,即针对多个字段建立一个组合索引。例如,可以使用以下语法为表article建立一个组合索引:ALTER TABLE article ADD INDEX index_title_time (title(50),time(10)).\[3\]在使用索引时,需要注意不对索引字段进行运算、格式转换、使用函数或多字段连接,以免影响索引使用效果。\[1\]总之,通过合理创建和使用索引,可以提高MySQL数据库的查询效率。 #### 引用[.reference_title] - *1* [mysql 索引创建与使用](https://blog.csdn.net/xiaojin21cen/article/details/84143342)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [MySQL索引的创建及使用](https://blog.csdn.net/qq_43846794/article/details/105453803)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [MySQL索引创建及使用](https://blog.csdn.net/yiXin_Chen/article/details/123413498)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

trigger333

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值