索引、序列

本文介绍了数据库中的序列创建与管理,包括起始值、增量、最大值等属性,并展示了如何修改和删除序列。同时,文章详细阐述了索引的作用、创建原则以及优缺点,强调了索引对查询速度和数据维护的影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.创建序列

    create sequence seq_1 

    start with 1 起始值

    increment by 1  每次递增

    maxvalue 20   最大值20

cycle cache 2 order 

通过序列给主键赋值 insert into student values(seq_1.nextval,'张三');

修改序列可以使用ALTER SEQUENCE语句进行修改。修改有一些限制如下:

初始值不能修改

序列的最小值不能大于当前序列的值

序列的最大值不能小于当前序列的值

例如:修改s_test序列的增长值为2

ALTER SEQUENCE s_test

INCREMENT BY 2;

查看序列情况

SELECT s_test.currval

FROM dual;

SELECT s_test.nextval

FROM dual;

删除s_test3序列

           DROP SEQUENCE s_test3;

2.索引

索引是与表关联的可选结构。可以创建索引以加快对表执行SQL语句的速度。就像书的索引可以帮助我们更快速的查找信息一样,Oracle中的索引也提供了一种更快地访问表数据的途径。

 应该建索引列的特点:

1)在经常需要搜索的列上,可以加快搜索的速度; 

2)在作为主键的列上,强制该列的唯一性和组织表中数据的排列结构; 

3)在经常用在连接的列上,这些列主要是一些外键,可以加快连接的速度; 

4)在经常需要根据范围进行搜索的列上创建索引,因为索引已经排序,其指定的范围是连续的; 

5)在经常需要排序的列上创建索引,因为索引已经排序,这样查询可以利用索引的排序,加快排序查询时间; 

6)在经常使用在WHERE子句中的列上面创建索引,加快条件的判断速度。

 

不应该建索引列的特点:

第一,对于那些在查询中很少使用或者参考的列不应该创建索引。

第二,对于那些只有很少数据值的列也不应该增加索引。 

第三,对于那些定义为blob数据类型的列不应该增加索引。

第四,当修改性能远远大于检索性能时,不应该创建索引。

 

优点:

第一,通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。 

第二,可以大大加快数据的检索速度,这也是创建索引的最主要的原因。 

第三,可以加速表和表之间的连接,特别是在实现数据的参考完整性方面特别有意义。 

第四,在使用分组和排序子句进行数据检索时,同样可以显著减少查询中分组和排序的时间。 

第五,通过使用索引,可以在查询的过程中,使用优化隐藏器,提高系统的性能。

 

缺点:

第一,创建索引和维护索引要耗费时间,这种时间随着数据量的增加而增加。  

第二,索引需要占物理空间,除了数据表占数据空间之外,每一个索引还要占一定的物理空间,如果要建立聚簇索引,那么需要的空间就会更大。 

第三,当对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,这样就降低了数据的维护速度。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值