• 专注于网站建设,网络推广,关键词优化,SEO优化,专业的网站建设开发团队!
首页 > IT技术 > MySQL > 内容

MySQL的常规索引index

2015-06-11 21:54:55   来源:叶景网络
    常规索引技术是关系数据查询中最重要的技术,如果要提升数据库的性能,索引优化是首先应该考虑的,因为它能使用我们的数据库得到最大性能方面的提升。如果没有索引的数据表,就没有排序的数据集合,要查询数据就需要进行全表扫描。有索引的表是一个在索引列上排序了的数据表,可通过索引快速定位记录。
    MyISAM数据表中数据保存在数据文件中,索引保存在索引文件(.MYI)中。而InnoDB数据表把数据与索引放在同一个文件中。
    常规索引的缺点:
    1)减慢在索引数据列上的插入、删除和修改操作。加了索引之后,insert、delete和update操作都要更新索引,会造成一些附加操作
    2)多占磁盘空间。索引是保存在物理文件(.MYI)里的,所以如果在一张大表上创建索引,会造成索引文件也比较大
    mysql语句中适用常规索引的地方
    在WHEERE(<,<=,=,>=,>,between,in,like)和join(on)子句,关联检索中的FROM子句,ORDER BY或GROUP BY子句中出现过的数据列。
    使用索引要注意什么?    
    索引是会消耗系统资源的,要适可而止。
    创建常规索引的方法
    原表:
    CREATE TABLE `wb_blog` (     
    `id` smallint(8) unsigned NOT NULL,     
    `catid` smallint(5) unsigned NOT NULL DEFAULT '0',     
    `title` varchar(80) NOT NULL DEFAULT '',     
    `content` text NOT NULL,     
    PRIMARY KEY (`id`),     
    )
    1、创建常规索引可以使用关键字KEY或INDEX随表一同创建,KEY通常是INDEX同义词
    mysql> CREATE TABLE `wb_blog` (     
    ->   `id` smallint(8) unsigned NOT NULL,     
    ->   `catid` smallint(5) unsigned NOT NULL DEFAULT '0',     
    ->   `title` varchar(80) NOT NULL DEFAULT '',     
    ->   `content` text NOT NULL,     
    ->   PRIMARY KEY (`id`),     
    ->   KEY `cat` (`catid`) #以字段catid为关键字定义名为cat的索引    
    -> );     
    Query OK, 0 rows affected (0.27 sec)
    2、在创建表之后使用CREATE INDEX 或ALTER TABLE 命令来创建
    mysql> create index  cat on wb_blog(catid);     
    Query OK, 0 rows affected (0.39 sec)
    删除常规索引的方法
    mysql> DROP INDEX cat ON wb_blog;     
    Query OK, 0 rows affected (0.34 sec)
叶景网络,网络推广,网站建设
特别推荐RECOMMEND
搜索引擎网站关键词seo优化的意义
视频推广怎么做
网站seo优化怎么做关键词排上首页?
SEO介绍什么叫搜索引擎网站关键词优化
seo优化怎样做提升关键词排名
热点图文Hot
MYSQL中导入大小超过2M的数据库文件解决办法 MYSQL中导入大小超
从MySQL中获得数据表auto_increment值的方法 从MySQL中获得数据
MySQL 错误1418 的原因分析及解决方法 MySQL 错误1418
MySQL group by 排序问题 MySQL group by 排序问题
关注排行RANKING
1

MYSQL中导入大小超过2M的数据库文件...

MYSQL中导入大小超过2M的数据库文件解决办法 叶景网络(www cngxit com),致力于互联网品牌建设与网络营销,专业领域包括网...

2

从MySQL中获得数据表auto_increment值的方法

从MySQL中获得数据表auto_increment值的方法 在插入一行数据前就想要知道将要产生的id。比如说想用来命名上传的文件。如果不事先...

3

MySQL 错误1418 的原因分析及解决方法

MySQL 错误1418 的原因分析及解决方法 叶景网络(www cngxit com),致力于互联网品牌建设与网络营销,专业领域包括网...

4

MySQL group by 排序问题

MySQL group by 排序问题 id 为 自动增长字段, tid为该回复的主题帖子的id(外键关联), subject 为回复...

5

MySQL-bin导致阿里云LNMP20G系统盘...

MySQL-bin导致阿里云LNMP20G系统盘不够用处理方法 在MySQL数据库中,mysql-bin 000001、mysql- bin 000002等文件是数据库的操作日志,...

6

LNMP更改网站文件和MySQL数据库的存放目录

LNMP更改网站文件和MySQL数据库的存放目录 购买阿里云服务器,一般建议买一个数据盘,也就是系统盘和数据盘分开,将网站文...

7

MySQL无法启动ERROR! MySQL is r...

MySQL无法启动ERROR! MySQL is running but PID file could not be found ? 叶景网络(www cngxit com),致力于互联网品牌建设与网络营销,专业领...

8

LNMP关闭MySQL日志保护硬盘空间

LNMP关闭MySQL日志保护硬盘空间 今天发现VPS硬盘居然快满了。第一反应是:肯定是某个东西的日志文件造成的,因为以前在W...

9

MySQL数据库批量修改表前缀的方法

MySQL数据库批量修改表前缀的方法 叶景网络(www cngxit com),致力于互联网品牌建设与网络营销,专业领域包括网...