数据库添加索引

1.MySQL在创建数据表的时候创建索引

在MySQL中创建表的时候,可以直接创建索引。基本的语法格式如下:

CREATE TABLE 表名(字段名 数据类型 [完整性约束条件],
                  [UNIQUE | FULLTEXT | SPATIAL] INDEX | KEY
                  [索引名](字段名1 [(长度)] [ASC | DESC])
);
  • UNIQUE:可选。表示索引为唯一性索引。
  • FULLTEXT;可选。表示索引为全文索引。
  • SPATIAL:可选。表示索引为空间索引。
  • INDEX和KEY:用于指定字段为索引,两者选择其中之一就可以了,作用是一样的。
  • 索引名:可选。给创建的索引取一个新名称。
  • 字段名1:指定索引对应的字段的名称,该字段必须是前面定义好的字段。
  • 长度:可选。指索引的长度,必须是字符串类型才可以使用。
  • ASC:可选。表示升序排列。
  • DESC:可选。表示降序排列。

MySQL创建普通索引

创建一个普通索引时,不需要加任何UNIQUE、FULLTEXT或者SPATIAL参数。

实例:创建一个名为index1的数据表,在表内的id字段上建立一个普通索引。

1. 创建普通索引的SQL代码如下:

CREATE TABLE index1(id INT,
                    name VARCHAR(20),
                    sex BOOLEAN,
                    INDEX(id)
);

          在DOS提示符窗口中查看MySQL创建普通索引的操作效果。如下图所示:

           

           从上图中可以看出,运行结果显示普通索引创建成功。

2. 使用SHOW CREATE TABLE语句查看表的结构。如下图所示:

               

              从上图中可以看出,在id字段上已经建立了一个名为id的普通索引。

      语句:

      KEY `id` (`id`)

圆括号内的id是字段名称,圆括号左侧外面的id是索引名称。

3. 使用EXPLAIN语句查看索引是否被使用。SQL代码如下:

    EXPLAIN SELECT * FROM index1 where id=1 \G

在DOS提示符窗口中查看使用EXPLAIN语句查看索引是否被使用的操作效果。如下图所示:

        

      上图中的结果显示,possible_keys和key的值都为id。说明id索引已经存在,并且查询时已经使用了索引。


MySQL创建唯一性索引

如果使用UNIQUE参数进行约束,则可以创建唯一性索引。

实例:创建一个名为index2的数据表,在表内的id字段上建立一个唯一性索引,并且设置id字段以升序的形式排列。

1. 创建一个唯一性索引的SQL代码如下:

CREATE TABLE index2(id INT UNIQUE,
                    name VARCHAR(20),
                    UNIQUE INDEX index2_id(id ASC)
);

index2_id是为唯一性索引起的一个新名字。

      在DOS提示符窗口中查看MySQL创建唯一性索引的操作效果。如下图所示:

        

        从上图中可以看出,运行结果显示创建成功。

2. 使用SHOW CREATE TABLE语句查看表的结构。SQL代码如下:

SHOW CREATE TABLE index2 \G

在DOS提示符窗口中查看使用SHOW CREATE TABLE语句查看表的结构的效果。如下图所示:

       

从上图中可以看出,在id字段上建立了名为id和index2_id的两个唯一性索引。这样做,可以提高数据的查询速度。

如果在创建index2表时,id字段没有进行唯一性结束。如下所示:

CREATE TABLE index2(id INT,
                    name VARCHAR(20),
                    UNIQUE INDEX index2_id(id ASC)
);

则也可以在id字段上成功创建名为index2_id的唯一性索引。但是,这样可能达不到提高查询速度的目的。


MySQL创建全文索引

全文索引使用FULLTEXT参数,并且只能在CHAR、VARCHAR或TEXT类型的字段上创建。

全文索引可以用于全文搜索。

现在,MyISAM存储引擎和InnoDB存储引擎都支持全文索引。

实例:创建一个名为index3的数据表,在表中的info字段上建立名为index3_info的全文索引。

1. 创建全文索引的SQL代码如下:

CREATE TABLE index3(id INT,
                    info VARCHAR(20),
                    FULLTEXT INDEX index3_info(info)
)ENGINE=MyISAM;

如果设置ENGINE=InnoDB,则可以在InnoDB存储引擎上创建全文索引。

在DOS提示符窗口中查看MySQL创建全文索引的操作效果。如下图所示:

         

从上图中可以看出,代码的执行结果显示创建成功。

2. 使用SHOW CREATE TABLE语句查看index3数据表的结构。如下图所示:

从上图中可以看出,在info字段上已经建立了一个名为index3_info的全文索引。

注意

我使用的是MySQL 5.6.19版本,已经可以在InnoDB存储引擎中创建全文索引了。

全文索引非常适合于大型数据集,对于小的数据集,它的用处可能比较小。


MySQL创建单列索引

单列索引是在数据表的单个字段上创建的索引。一个表中可以创建多个单列索引。唯一性索引和普通索引等都为单列索引。

实例:创建一个名为index4的数据表,在表中的subject字段上建立名为index4_st的单列索引。

1. 创建单列索引的SQL代码如下:

CREATE TABLE index4(id INT,
                    subject VARCHAR(30),
                    INDEX index4_st(subject(10))
);

在DOS提示符窗口中查看MySQL创建单列索引的操作效果。如下图所示:

       

从上图中可以看出,代码执行的结果显示创建成功。

2. 使用SHOW CREATE TABLE语句查看index4数据表的结构。如下图所示:

          

从上图中可以看出,在subject字段上已经建立了一个名为index4_st的单列索引。

注意:subject字段长度为30,而index4_st设置的索引长度只有10,这样做是为了提高查询速度。对于字符型的数据,可以不用查询全部信息,而只查询它前面的若干字符信息。


MySQL创建多列索引

创建多列索引是在表的多个字段上创建一个索引。

实例:创建一个名为index5的数据表,在表中的name和sex字段上建立名为index5_ns的多列索引。

1. 创建多列索引的SQL代码如下:

CREATE TABLE index5(id INT,
                    name VARCHAR(20),
                    sex CHAR(4),
                    INDEX index5_ns(name,sex)
);

在DOS提示符窗口中查看MySQL创建多列索引的操作效果。如下图所示:

        

从上图中可以看出,代码的执行结果显示index5_ns索引创建成功。

2. 使用SHOW CREATE TABLE语句查看index5数据表的结构。如下图所示:

         

从上图中可以看出,name和sex字段上已经建立了一个名为index5_ns的多列索引。

3. 多列索引中,只有查询条件中使用了这些字段中第一个字段时,索引才会被使用。

先在index5数据表中添加一些数据记录,然后使用EXPLAIN语句可以查看索引的使用情况。如果只是使用name字段作为查询条件进行查询。如下图所示:

          

从上图中可以看出,possible_keys和key的值都是index5_ns。Extra(额外信息)显示正在使用索引。这说明使用name字段进行索引时,索引index5_ns已经被使用。

4. 如果只使用sex字段作为查询条件进行查询。如下图所示:

           

从上图中可以看出,possible_keys和key的值都是NULL。Extra(额外信息)显示正在使用where条件查询,而未使用索引。

提示

使用多列索引时一定要特别注意,只有使用了索引中的第一个字段时才会触发索引。如果没有使用索引中的第一个字段,那么这个多列索引就不会起作用。因此,在优化查询速度时,可以考虑优化多列索引。


MySQL创建空间索引

使用SPATIAL参数能够创建空间索引。创建空间索引时,表的存储引擎必须是MyISAM类型。而且,索引字段必须有非空约束。

实例:创建一个名为index6的数据表,在表中的space字段上建立名为index6_sp的空间索引。

1. 创建空间索引的SQL代码如下:

CREATE TABLE index6(id INT,
                    space GEOMETRY NOT NULL,
                    SPATIAL INDEX index6_sp(space)
)ENGINE=MyISAM;

在DOS提示符窗口中查看MySQL创建空间索引的操作效果。如下图所示:

       

从上图可以看出,代码执行的结果显示空间索引创建成功。

2. 使用SHOW CREATE TABLE语句可看index6数据表的结构。如下图所示:

        

从上图中可以看出,在space字段上已经建立了一个名为index6_sp的空间索引。

注意,space字段是非空的,而且数据类型是GEOMETRY类型。这个类型是空间数据类型。

空间数据类型包括GEOMETRY、POINT、LINESTRING和POLYGON类型等。这些空间数据类型平时很少用到

2添加索引

1.添加PRIMARY KEY(主键索引) 
mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 
2.添加UNIQUE(唯一索引) 
mysql>ALTER TABLE `table_name` ADD UNIQUE ( 
`column` 

3.添加INDEX(普通索引) 
mysql>ALTER TABLE `table_name` ADD INDEX index_name ( `column` ) 
4.添加FULLTEXT(全文索引) 
mysql>ALTER TABLE `table_name` ADD FULLTEXT ( `column`) 
5.添加多列索引 
mysql>ALTER TABLE `table_name` ADD INDEX index_name ( `column1`, `column2`, `column3` )

  • 8
    点赞
  • 45
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在Oracle数据库中,可以通过以下步骤添加索引: 1. 首先选择需要添加索引的表以及需要添加索引的列。 2. 然后使用CREATE INDEX语句创建索引。例如: ``` CREATE INDEX index_name ON table_name (column1, column2, ...); ``` 这将在指定的表上创建一个名为“index_name”的索引,该索引将根据指定的列(column1,column2等)进行排序。 3. 如果需要更高级的索引选项,可以在CREATE INDEX语句中使用其他选项。例如: ``` CREATE INDEX index_name ON table_name (column1, column2, ...) TABLESPACE tablespace_name PCTFREE 10 INITRANS 2; ``` 这将创建一个名为“index_name”的索引,将使用指定的表空间(tablespace_name),并使用10%的空闲空间以及2个并发事务。 4. 添加索引后,可以使用EXPLAIN PLAN语句来检查查询是否使用了新的索引。例如: ``` EXPLAIN PLAN FOR SELECT * FROM table_name WHERE column1 = 'value'; ``` 这将为指定的查询生成一个执行计划,可以从中检查是否使用了新的索引。 注意,在添加索引之前,需要仔细考虑哪些列需要索引,以及如何优化查询性能。添加过多的索引可能会导致性能下降。 ### 回答2: Oracle数据库添加索引是提高查询性能的重要手段之一。下面是关于如何在Oracle数据库添加索引的步骤和注意事项。 1. 确定需要添加索引的表和列:在设计索引之前,首先需要确定需要添加索引的表和列。通常来说,选择那些经常在查询中使用的列作为索引列是最合适的。 2. 判断索引类型:在Oracle数据库中,有多种类型的索引可供选择,如B树索引、位图索引等。根据具体需求和表的结构来选择合适的索引类型。 3. 创建索引:使用CREATE INDEX语句创建索引。例如,创建单列B树索引可以使用如下语句: CREATE INDEX index_name ON table_name(column_name); 4. 考虑索引优化:在创建索引时,你可以通过指定索引参数来优化索引的性能。例如,可以使用PARALLEL参数来指定索引的并行度,使用COMPUTE STATISTICS参数来收集索引的统计信息等。 5. 更新索引统计信息:使用DBMS_STATS包中的过程来更新表和索引的统计信息。这样可以确保Oracle数据库优化查询计划。 6. 测试索引性能:在添加索引之后,需要进行性能测试来验证索引的效果。可以选择一些常见的查询,并比较带索引和不带索引的查询执行时间。 添加索引也需要注意一些事项: 1. 不要滥用索引:虽然索引可以提高查询性能,但是过多的索引也会带来额外的开销。因此,在添加索引之前,需要仔细考虑是否真的需要索引,并在必要的列上添加。 2. 定期维护索引索引需要定期进行维护,包括重新构建索引、更新统计信息等。这样可以保证索引一直保持最佳性能。 3. 考虑空间使用:添加索引会占用额外的存储空间。因此,在创建索引时,需要考虑存储空间的使用情况,并确保有足够的空间来支持索引。 总之,通过合理的索引设计和维护,可以显著提高Oracle数据库的查询性能。但是需要注意的是,在添加索引之前,需要仔细考虑选择的列和索引类型,并定期对索引进行维护。 ### 回答3: Oracle数据库添加索引是为了提高查询效率和加快数据检索的速度。索引是在表或者视图上创建的一种数据结构,可以帮助数据库系统快速定位到具有特定值的数据行。 要添加索引,首先需要确定要创建索引的表或者视图。在确定了目标表或视图之后,可以选择要创建索引的列或者字段。通常选择那些在查询中频繁被用作搜索条件或者参与连接的列或者字段作为索引的候选。 Oracle数据库提供了多种类型的索引,包括B树索引、位图索引、位图联合索引、函数索引等。根据具体的需求和数据结构,选择适合的索引类型。然后使用CREATE INDEX语句创建索引。在创建索引时,可以设置索引的名称、表空间、索引类型、列或者字段列表等信息。 添加索引的优点是可以加快查询的速度,特别是对于大数据量的表或者视图来说,可以显著减少查询时间。但也需要注意,索引并非越多越好,因为索引也会占用存储空间。过多的索引会增加数据库的维护成本,并可能导致更新操作的性能下降。 另外,需要定期对索引进行维护和优化。可以使用索引重建或者在线重组等方法来消除索引的碎片,并保持索引的高效性。 综上所述,Oracle数据库添加索引是一种优化数据库性能的方法,通过创建适当类型的索引来提高查询效率和数据检索速度。但需要根据实际情况进行选择,避免过多索引造成资源浪费,并定期对索引进行维护和优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值