Mysql入门mysql索引创建方法 mysql数据库索引例解

Mysql入门mysql索引创建方法 mysql数据库索引例解,第1张

概述介绍《Mysql入门mysql索引创建方法 mysql数据库索引例解》开发教程,希望对您有用。

《MysqL入门MysqL索引创建方法 MysqL数据库索引例解》要点:
本文介绍了MysqL入门MysqL索引创建方法 MysqL数据库索引例解,希望对您有用。如果有疑问,可以联系我们。

导读:有关MysqL索引的创建与管理.1,为出现在where子句的字段建一个索引.首先,创建如下表:CREATE table mytable ( ID serial primary...

MysqL学习有关MysqL索引的创建与管理.

MysqL学习1,为出现在where子句的字段建一个索引.
首先,创建如下表:
 

CREATE table mytable (
 ID serial primary key,
 category_ID int not null default 0,
 user_ID int not null default 0,
 adddate int not null default 0
);

MysqL学习然后是查询语句:
 

SELECT * FROM mytable WHERE category_ID=1;

MysqL学习最直接的应对之道,是为category_ID建立一个简单的索引:
 

CREATE INDEX mytable_categoryID
 ON mytable (category_ID);

MysqL学习先别高兴,如果有不止一个选择条件呢?例如:
 

SELECT * FROM mytable WHERE category_ID=1 AND user_ID=2;

MysqL学习再给user_ID建立一个索引.不好,这不是一个最佳的办法.你可以建立多重的索引.
 

CREATE INDEX mytable_categoryID_userID ON mytable (category_ID,user_ID);

MysqL学习注意,我在命名时的习惯了吗?我使用"表名_字段1名_字段2名"的方式.
现在,已经为适当的字段建立了索引,不过,还是有点不放心吧,可能会问,数据库会真正用到这些索引吗?
测试下对于大多数的数据库来说,这是很容易的,只要使用EXPLAIN命令:
 

MysqL学习EXPLAIN
 SELECT * FROM mytable
  WHERE category_ID=1 AND user_ID=2;

MysqL学习This is what Postgres 7.1 returns (exactly as I expected)

MysqL学习 NOTICE: query PLAN:

MysqL学习Index Scan using mytable_categoryID_userID on
  mytable (cost=0.00..2.02 rows=1 wIDth=16)

MysqL学习EXPLAIN

MysqL学习以上是postgres的数据,可以看到该数据库在查询的时候使用了一个索引(一个好开始),而且它使用的是我创建的第二个索引.看到我上面命名的好处了吧,你马上知道它使用适当的索引了.

MysqL学习接着,来个稍微复杂一点的,如果有个ORDER BY字句呢?不管你信不信,大多数的数据库在使用order by的时候,都将会从索引中受益.
 

SELECT * FROM mytable
  WHERE category_ID=1 AND user_ID=2
    ORDER BY adddate DESC;

MysqL学习很简单,就象为where字句中的字段建立一个索引一样,也为ORDER BY的字句中的字段建立一个索引:
 

CREATE INDEX mytable_categoryID_userID_adddate
  ON mytable (category_ID,user_ID,adddate);

MysqL学习注意: "mytable_categoryID_userID_adddate" 将会被截短为
 

MysqL学习"mytable_categoryID_userID_addda"
CREATE
  EXPLAIN SELECT * FROM mytable
  WHERE category_ID=1 AND user_ID=2
   ORDER BY adddate DESC;

MysqL学习 NOTICE: query PLAN:

MysqL学习 Sort (cost=2.03..2.03 rows=1 wIDth=16)
  -> Index Scan using mytable_categoryID_userID_addda
    on mytable (cost=0.00..2.02 rows=1 wIDth=16)
EXPLAIN

MysqL学习
  看看EXPLAIN的输出,好象有点恐怖啊,数据库多做了一个我们没有要求的排序,这下知道性能如何受损了吧,看来我们对于数据库的自身运作是有点过于乐观了,那么,给数据库多一点提示吧.

MysqL学习  为了跳过排序这一步,我们并不需要其它另外的索引,只要将查询语句稍微改一下.这里用的是postgres,我们将给该数据库一个额外的提示--在ORDER BY语句中,加入where语句中的字段.这只是一个技术上的处理,并不是必须的,因为实际上在另外两个字段上,并不会有任何的排序 *** 作,不过如果加入,postgres将会知道哪些是它应该做的.
 

MysqL学习EXPLAIN SELECT * FROM mytable
  WHERE category_ID=1 AND user_ID=2
  ORDER BY category_ID DESC,user_ID DESC,adddate DESC;

MysqL学习NOTICE: query PLAN:

MysqL学习Index Scan Backward using
 mytable_categoryID_userID_addda on mytable
   (cost=0.00..2.02 rows=1 wIDth=16)
EXPLAIN

MysqL学习现在使用索引,而且它还挺聪明,知道可以从索引后面开始读,从而避免了任何的排序.

MysqL学习以上说得细了一点,不过如果你的数据库非常巨大,并且每日的页面哀求达上百万算,我想你会获益良多的.不过,如果你要做更为复杂的查询呢,例如将多张表结合起来查询,特别是where限制字句中的字段是来自不止一个表格时,应该怎样处理呢?我通常都尽量避免这种做法,因为这样数据库要将各个表中的东西都结合起来,然后再排除那些不合适的行,搞不好开销会很大.

MysqL学习如果不能避免,你应该查看每张要结合起来的表,并且使用以上的策略来建立索引,然后再用EXPLAIN命令验证一下是否使用了你料想中的索引.如果是的话,就OK.不是的话,你可能要建立临时的表来将他们结合在一起,并且使用适当的索引.

MysqL学习注意,建立太多的索引将会影响更新和插入的速度,因为它需要同样更新每个索引文件.对于一个经常需要更新和插入的表格,就没有必要为一个很少使用的where字句单独建立索引了,对于比较小的表,排序的开销不会很大,也没有必要建立另外的索引.

MysqL学习以上介绍的只是一些十分基本的东西,其实里面的学问也不少,单凭EXPLAIN我们是不能判定该办法是否就是最优化的,每个数据库都有自己的一些优化器,虽然可能还不太完善,但是它们都会在查询时对比过哪种方式较快,在某些情况下,建立索引的话也未必会快,例如索引放在一个不连续的存储空间时,这会增加读磁盘的负担,因此,哪个是最优,应该通过实际的使用环境来检验.

MysqL学习在刚开始的时候,如果表不大,没有必要作索引,我的意见是在需要的时候才作索引,也可用一些命令来优化表,例如MysqL可用"OPTIMIZE table".

MysqL学习综上所述,在如何为数据库建立恰当的索引方面,你应该有一些基本的概念了.

MysqL索引类型区别分析
MysqL索引的类型与优缺点
MysqL索引优化注意问题
MysqL索引优化实例解析
MysqL索引优化应用实例
MysqL索引分类与优化
MysqL索引优化注意要点
MysqL索引优化办法解析
深入理解MysqL索引与优化

内存溢出PHP培训学院每天发布《MysqL入门MysqL索引创建方法 MysqL数据库索引例解》等实战技能,PHP、MysqL、liNUX、APP、Js,CSS全面培养人才。

总结

以上是内存溢出为你收集整理的Mysql入门mysql索引创建方法 mysql数据库索引例解全部内容,希望文章能够帮你解决Mysql入门mysql索引创建方法 mysql数据库索引例解所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/1156030.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存