• 技术文章 >后端开发 >php教程

    为数据库建立索引一_PHP教程

    2016-07-13 17:26:17原创316
    就象许多的PHP开发者一样,在刚开始建立动态网站的时候,我都是使用相对简单的数据结构。PHP在连接数据库方面的确实是十分方便(译者注:有些人认为PHP在连接不同数据库时没有一个统一的接口,不太方便,其实这可以通过一些扩展库来做到这一点),你无需看大量的设计文档就可以建立和使用数据库,这也是PHP获得成功的主要原因之一。
      前些时候,一位颇高级的程序员居然问我什么叫做索引,令我感到十分的惊奇,我想这绝不会是沧海一粟,因为有成千上万的开发者(可能大部分是使用MySQL的)都没有受过有关数据库的正规培训,尽管他们都为客户做过一些开发,但却对如何为数据库建立适当的索引所知较少,因此我起了写一篇相关文章的念头。
      最普通的情况,是为出现在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
      );
      很简单吧,不过对于要说明这个问题,已经足够了。如果你在查询时常用类似以下的语句:
       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命令:
      EXPLAIN
       SELECT * FROM mytable
        WHERE category_id=1 AND user_id=2;
       This is what Postgres 7.1 returns (exactly as I expected)
       NOTICE: QUERY PLAN:
       Index Scan using mytable_categoryid_userid on
         mytable (cost=0.00..2.02 rows=1 width=16)
      EXPLAIN
    以上是postgres的数据,可以看到该数据库在查询的时候使用了一个索引(一个好开始),而且它使用的是我创建的第二个索引。看到我上面命名的好处了吧,你马上知道它使用适当的索引了。

    www.bkjia.comtruehttp://www.bkjia.com/PHPjc/531988.htmlTechArticle就象许多的PHP开发者一样,在刚开始建立动态网站的时候,我都是使用相对简单的数据结构。PHP在连接数据库方面的确实是十分方便(译者...

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐: 数据库 建立 索引 就象 许多的 多的 PHP 开发者 一样 刚开始 建立 动态 站的 时候
    上一篇:PEARMDB数据库抽象层——一次编写—随处运行_PHP教程 下一篇:PHP缩略图生成程序_PHP教程
    千万级数据并发解决方案

    相关文章推荐

    • php 插入100万条.和对比100万条,差距?• 打开php错误提示 nginx+php• Linux php 中文乱码的快速解决方法,_PHP教程• 浅析Yii2 GridView 日期格式化并实现日期可搜索教程,yii2gridview_PHP教程• Zend Framework基本页面布局分析,zendframework_PHP教程
    1/1

    PHP中文网