网站地图    收藏   

主页 > php专栏 > php应用 >

php为数据库建立索引 - php高级应用

来源:自学PHP网    时间:2014-11-27 22:16 作者: 阅读:

[导读] 就象许多的PHP开发者一样,在刚开始建立动态网站的时候,我都是使用相对简单的数据结构,PHP在连接数据库方面的确实是十分方便,译者注,有些人认为PHP在连接不同数据库时没有一个统一的...

php为数据库建立索引

就象许多的PHP开发者一样,在刚开始建立动态网站的时候,我都是使用相对简单的数据结构,PHP在连接数据库方面的确实是十分方便,译者注,有些人认为PHP在连接不同数据库时没有一个统一的接口,不太方便,其实这可以通过一些扩展库来做到这一点,你无需看大量的设计文档就可以建立和使用数据库,这也是PHP获得成功的主要原因之一.

前些时候,一位颇高级的程序员居然问我什么叫做索引,令我感到十分的惊异,我想这绝不会是沧海一粟,因为有成千上万的开发者,可能大部分是使用MySQL的,都没有受过有关数据库的正规培训,尽管他们都为客户做过一些开发,但却对如何为数据库建立适当的索引所知较少,因此我起了写一篇相关文章的念头.

最普通的情况,是为出现在where子句的字段建一个索引,为方便讲述,我们先建立一个如下的表.

  1. CREATE TABLE mytable ( 
  2.    id serial primary key
  3.    category_id int not null default 0, 
  4.    user_id int not null default 0, 
  5.    adddate int not null default 0 
  6. ); 

很简单吧,不过对于要说明这个问题,已经足够了,假如你在查询时常用类似以下的语句:

SELECT * FROM mytable WHERE category_id=1;

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

CREATE INDEX mytable_categoryid

ON mytable (category_id);

OK,搞定?先别兴奋,假如你有不止一个选择条件呢?例如:

SELECT * FROM mytable WHERE category_id=1 AND user_id=2;

你的第一反应可能是,再给user_id建立一个索引,不好,这不是一个最佳的方法,你可以建立多重的索引.

CREATE INDEX mytable_categoryid_userid ON mytable (category_id,user_id);

注意到我在命名时的习惯了吗?我使用"表名_字段1名_字段2名"的方式,你很快就会知道我为什么这样做了.

现在你已经为适当的字段建立了索引,不过,还是有点不放心吧,你可能会问,数据库会真正用到这些索引吗?测试一下就OK,对于大多数的数据库来说,这是很轻易的,只要使用EXPLAIN命令:

  1. EXPLAIN 
  2.  
  3.  SELECT * FROM mytable 
  4.   WHERE category_id=1 AND user_id=2; 
  5.  
  6.  This is what Postgres 7.1 returns (exactly as I expected) 
  7.  
  8.  NOTICE: QUERY PLAN: 
  9.  
  10.  Index Scan using mytable_categoryid_userid on 
  11.    mytable (cost=0.00..2.02 rows=1 width=16) 
  12.       //开源代码phpfensi.com 
  13. EXPLAIN 

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

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

SELECT * FROM mytable

WHERE category_id=1 AND user_id=2

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论