加速PHP动态网站 关于MySQL索引分析优化

2016-02-19 21:47 4 1 收藏

下面是个加速PHP动态网站 关于MySQL索引分析优化教程,撑握了其技术要点,学起来就简单多了。赶紧跟着图老师小编一起来看看吧!

【 tulaoshi.com - Web开发 】

 

本文主要讲述了如何加速动态网站的MySQL索引分析和优化。 iSH中国教程在线

一、什么是索引? iSH中国教程在线

索引用来快速地寻找那些具有特定值的记录,所有MySQL索引都以B-树的形式保存。如果没有索引,执行查询时MySQL必须从第一个记录开始扫描整个表的所有记录,直至找到符合要求的记录。表里面的记录数量越多,这个操作的代价就越高。如果作为搜索条件的列上已经创建了索引,MySQL无需扫描任何记录即可迅速得到目标记录所在的位置。如果表有1000个记录,通过索引查找记录至少要比顺序扫描记录快100倍。 iSH中国教程在线

假设我们创建了一个名为people的表: iSH中国教程在线

CREATE TABLE people ( peopleid SMALLINT NOT NULL, iSH中国教程在线

name CHAR(50) NOT NULL );iSH中国教程在线

然后,我们完全随机把1000个不同name值插入到people表。在数据文件中name列没有任何明确的次序。如果我们创建了name列的索引,MySQL将在索引中排序name列,对于索引中的每一项,MySQL在内部为它保存一个数据文件中实际记录所在位置的“指针”。因此,如果我们要查找name等于“Mike”记录的peopleid(SQL命令为“SELECT peopleid FROM people WHERE name='Mike';”),MySQL能够在name的索引中查找“Mike”值,然后直接转到数据文件中相应的行,准确地返回该行的peopleid(999)。在这个过程中,MySQL只需处理一个行就可以返回结果。如果没有“name”列的索引,MySQL要扫描数据文件中的所有记录,即1000个记录!显然,需要MySQL处理的记录数量越少,则它完成任务的速度就越快。 iSH中国教程在线

二、索引的类型 iSH中国教程在线

MySQL提供多种索引类型供选择: iSH中国教程在线

普通索引 : iSH中国教程在线

这是最基本的索引类型,而且它没有唯一性之类的限制。普通索引可以通过以下几种方式创建: iSH中国教程在线

创建索引,例如CREATE INDEX 索引的名字 ON tablename (列的列表); iSH中国教程在线

修改表,例如ALTER TABLE tablename ADD INDEX [索引的名字] (列的列表); iSH中国教程在线

创建表的时候指定索引,例如CREATE TABLE tablename ( [...], INDEX [索引的名字] (列的列表) ); iSH中国教程在线

唯一性索引: iSH中国教程在线

这种索引和前面的“普通索引”基本相同,但有一个区别:索引列的所有值都只能出现一次,即必须唯一。唯一性索引可以用以下几种方式创建: iSH中国教程在线

创建索引,例如CREATE UNIQUE INDEX 索引的名字 ON tablename (列的列表); iSH中国教程在线

修改表,例如ALTER TABLE tablename ADD UNIQUE [索引的名字] (列的列表); iSH中国教程在线

创建表的时候指定索引,例如CREATE TABLE tablename ( [...], UNIQUE [索引的名字] (列的列表) ); iSH中国教程在线

主键 : iSH中国教程在线

主键是一种唯一性索引,但它必须指定为“PRIMARY KEY”。如果你曾经用过AUTO_INCREMENT类型的列,你可能已经熟悉主键之类的概念了。主键一般在创建表的时候指定,例如“CREATE TABLE tablename ( [...], PRIMARY KEY (列的列表) ); ”。但是,我们也可以通过修改表的方式加入主键,例如“ALTER TABLE tablename ADD PRIMARY KEY (列的列表); ”。每个表只能有一个主键。 iSH中国教程在线

全文索引: iSH中国教程在线

MySQL从3.23.23版开始支持全文索引和全文检索。在MySQL中,全文索引的索引类型为FULLTEXT。全文索引可以在VARCHAR或者TEXT类型的列上创建。它可以通过CREATE TABLE命令创建,也可以通过ALTER TABLE或CREATE INDEX命令创建。对于大规模的数据集,通过ALTER TABLE(或者CREATE INDEX)命令创建全文索引要比把记录插入带有全文索引的空表更快。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

来源:https://www.tulaoshi.com/n/20160219/1627171.html

延伸阅读
标签: ASP
  方法一 <% '常用函数 '1、输入url目标网页地址,返回值getHTTPPage是目标网页的html代码 function getHTTPPage(url) dim Http set Http=server.createobject("MSXML2.XMLHTTP") Http.open "GET",url,false Http.send() if Http.readystate<4 then exit function end if getHTTPPage=bytesToBSTR(Http.responseBody,"GB2312") ...
关于建立索引的几个准则: 1、合理的建立索引能够加速数据读取效率,不合理的建立索引反而会拖慢数据库的响应速度。 2、索引越多,更新数据的速度越慢。 3、尽量在采用MyIsam作为引擎的时候使用索引(因为MySQL以BTree存储索引),而不是InnoDB。但MyISAM不支持Transcation。 4、当你的程序和数据库结构/SQL语句已经优化到无法优化的程度...
简介:PHP+MYSQL网站注入扫描工具,针对类似夜猫文章下 载系统比较有效,界面是仿教程的hdsi中的PHP注入模块写 的,实现原理是参考angel的SQL Injection with MYSQL 写的,网上有很多,不再细说。 界面截图: http://www.wrsky.com/attachment/3_1891.jpg 源码下载: http://downloads.2ccc.com/general/inter...
问题描述: 我们要访问的表是一个非常大的表,四千万条记录,id是主键,program_id上建了索引。 执行一条SQL: select * from program_access_log where program_id between 1 and 4000 这条SQL非常慢。 我们原以为处理记录太多的原因,所以加了id限制,一次只读五十万条记录 select * from program_access_l...
标签: Web开发
诊断了网站的弊症所在,然后就可以制定改版策略。制定好改版策略之后,我们就该对网站的用户进行系统的分析了。 网站同样需要以人为本。只有准确把握用户需求,才能做出用户真正喜欢的网站。如果不考虑用户需求,网站的页面设计得再漂亮,功能再强大,也只能作为摆设,无法吸引到用户,更谈不上将网站用户变为你的客户。 1、用户类...

经验教程

400

收藏

41
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部