zoukankan      html  css  js  c++  java
  • 在已经存在的表上创建索引

    在已经存在的表中,可以直接为表上的一个或几个字段创建索引。基本形式如下:

    1. CREATE  [ UNIQUE | FULLTEXT | SPATIAL ]  INDEX  索引名  
    2.  ON  表名  (属性名  [ (长度) ]  [  ASC | DESC] ); 

    其中,UNIQUE是可选参数,表示索引为唯一性索引;FULLTEXT是可选参数,表示索引为全文索引;SPATIAL也是可选参数,表示索引为空间索引;"INDEX"参数用来指定字段为索引的;"索引名"参数是给创建的索引取的新名称;"表名"参数是指需要创建索引的表的名称,该表必须是已经存在的,如果不存在,需要先创建;"属性名"参数指定索引对应的字段的名称,该字段必须为前面定义好的字段;"长度"是可选参数,其指索引的长度,必须是字符串类型才可以使用;ASC和DESC都是可选参数,ASC参数表示升序排列,DESC参数表示降序排列。

    1.创建普通索引

    【示例7-7】 下面在example0表中的id字段上建立名为index7_id的索引。SQL代码如下:

    1. CREATE  INDEX  index7_id  ON  example0 ( id ) ; 

    在创建索引之前,先使用SHOW CREATE TABLE语句查看example0表的结构,显示如下:

    1. mysql> SHOW CREATE TABLE example0 \G  
    2. *************************** 1. row ***************************  
    3.        Table: example0  
    4. Create Table: CREATE TABLE `example0` (  
    5.   `id` int(11) DEFAULT NULL,  
    6.   `name` varchar(20) DEFAULT NULL,  
    7.   `sex` tinyint(1) DEFAULT NULL  
    8. ENGINE=InnoDB DEFAULT CHARSET=utf8 
    9. 1 row in set (0.08 sec) 

    查询结果显示,example0表还没有索引。下面使用CREATE INDEX语句创建索引。CREATE INDEX语句执行结果如下:

    1. mysql> CREATE  INDEX  index7_id  ON  example0 ( id ) ;  
    2. Query OK, 0 rows affected (0.06 sec)  
    3. Records: 0  Duplicates: 0  Warnings: 0 

    运行结果显示创建成功,使用SHOW CREATE TABLE语句查看表的结构。显示如下:

    1. mysql> SHOW CREATE TABLE example0 \G  
    2. *************************** 1. row **************************  
    3.        Table: example0  
    4. Create Table: CREATE TABLE `example0` (  
    5.   `id` int(11) DEFAULT NULL,  
    6.   `name` varchar(20) DEFAULT NULL,  
    7.   `sex` tinyint(1) DEFAULT NULL,  
    8.   KEY `index7_id` (`id`)  
    9. ENGINE=InnoDB DEFAULT CHARSET=utf8 
    10. 1 row in set (0.00 sec) 

    结果可以看到,example0表中的id字段上已经创建了一个名为index7_id的索引。这表示使用CREATE INDEX语句成功的在example0表上创建了普通索引。

    2.创建唯一性索引

    【示例7-8】 下面在index8表中的course_id字段上建立名为index8_id的唯一性索引。SQL代码如下:

    CREATE  UNIQUE  INDEX  index8_id  ON  index8( course_id ) ;

    其中,index8_id为索引的名词;UNIQUE用来设置索引为唯一性索引;表index8中的course_id字段可以有唯一性约束,也可以没有唯一性约束。

    3.创建全文索引

    【示例7-9】 下面在index9表中的info字段上建立名为index9_info的全文索引。SQL代码如下:

    1. CREATE  FULLTEXT  INDEX  index9_info  ON  index9( info ) ; 

    其中,FULLTEXT用来设置索引为全文索引;表index9的存储引擎必须是MyISAM类型;info字段必须为CHAR、VARCHAR和TEXT等类型。

    4.创建单列索引

    【示例7-10】 下面在index10表中的address字段上建立名为index10_addr的单列索引。address字段的数据类型为VARCHAR(20),索引的数据类型为CHAR(4)。SQL代码如下:

    1. CREATE  INDEX  index10_addr  ON  index10( address(4) ) ; 

    这样,查询时可以只查询address字段的前4个字符,而不需要全部查询。

    5.创建多列索引

    【示例7-11】 下面在index11表中的name和address字段上建立名为index11_na的多列索引。SQL代码如下:

    1. CREATE  INDEX  index11_na  ON  index11( name, address ) ; 

    该索引创建好了以后,查询条件中必须有name字段才能使用索引。

    6.创建空间索引

    【示例7-12】 下面在index12表中的line字段上建立名为index12_line的多列索引。SQL代码如下:

    1. CREATE  SPATIAL  INDEX  index12_line  ON  index12( line ) ; 

    其中,SPATIAL用来设置索引为空间索引;表index12的存储引擎必须是MyISAM类型;line字段必须为空间数据类型,而且是非空的。

  • 相关阅读:
    作业2019.1.15
    面向对象
    Arrays类的常用方法
    堆和栈的区别
    吃货联盟订餐系统
    解决Navicat连接MySQL出现1251-Client does not support authentication protocol requested by server;
    k-进制数
    怎么用宝塔面板搭建一个网站?
    Win10启动修复无法修复你的电脑解决方法
    java HashMap怎么用
  • 原文地址:https://www.cnblogs.com/yinchengliang/p/2487412.html
Copyright © 2011-2022 走看看