您现在的位置是:群英 > 数据库 > 关系型数据库
oracle中建立索引有什么用,什么时候使用索引
Admin发表于 2022-08-09 17:54:481194 次浏览
相信很多人对“oracle中建立索引有什么用,什么时候使用索引”都不太了解,下面群英小编为你详细解释一下这个问题,希望对你有一定的帮助

   

在oracle中,索引是一种供服务器在表中快速查找一个行的数据库结构,是建立在表的一列或者多列上的辅助对象,目的是加快访问表中的数据。索引的作用:1、快速存取数据;2、既可以改善数据库性能,又可以保证列值的唯一性等等。

本教程操作环境:Windows7系统、Oracle 11g版、Dell G3电脑。

什么是索引?

在oracle中,索引是一种供服务器在表中快速查找一个行的数据库结构。

  • 索引是建立在表的一列或者多列上的辅助对象,目的是加快访问表中的数据。

  • oracle 存储索引的结构是B*数(平衡树),而索引是由根节点、分支点和叶子点组成,上级索引块包含下级索引块的索引数据,叶节点包含索引数据和确定行实际位置的rowid。

在数据库中建立索引主要有以下作用:

(1)快速存取数据。

(2)减少I/O操作

(3)既可以改善数据库性能,又可以保证列值的唯一性。

(4)实现表与表之间的参照完整性

(5)在使用orderby、groupby子句进行数据检索时,利用索引可以减少排序和分组的时间。

什么时候用:

  • 作为where后查询条件的字段适合建立索引。

什么时候不用:

  • 重复字段较多;

  • 不作为where后查询条件的字段;

  • 表中记录较少。

怎么用索引:

创建索引:

CREATE [UNIQUE] | [BITMAP] INDEX index_name  --unique表示唯一索引
ON table_name([column1 [ASC|DESC],column2    --bitmap,创建位图索引
[ASC|DESC],…] | [express])
[TABLESPACE tablespace_name]
[PCTFREE n1]                                 --指定索引在数据块中空闲空间
[STORAGE (INITIAL n2)]
[NOLOGGING]                                  --表示创建和重建索引时允许对表做DML操作,默认情况下不应该使用
[NOLINE]
[NOSORT];                                    --表示创建索引时不进行排序,默认不适用,如果数据已经是按照该索引顺序排列的可以使用

例如,

创建商品表:

-- Create table
create table TB_GOODS
(
  goods_id    VARCHAR2(64) not null,
  goods_name  VARCHAR2(256) not null,
  goods_price VARCHAR2(64) not null,
  status      VARCHAR2(1) not null
);

创建索引:

--这里unique可以省略,若省略则索引为非唯一索引
create index UI_tb_goods on tb_goods(goods_name);
--若使用unique则为唯一索引
create unique index un_tb_goods on tb_goods(goods_name);
--括号中添加两列则为组合索引
create unique index un2_tb_goods on tb_goods(goods_name,status);
--括号中添加三列,其顺序没有关系,效果是一样的
create unique index un3_tb_goods on tb_goods(goods_name,goods_price,status);

唯一索引的另一个作用,控制该列不能有相同值!

查询索引:

select * from user_indexes where table_name='表名';
select * from user_ind_columns  where index_name='索引名';

到此这篇关于“oracle中建立索引有什么用,什么时候使用索引”的文章就介绍到这了,感谢各位的阅读,更多相关oracle中建立索引有什么用,什么时候使用索引内容,欢迎关注群英网络资讯频道,小编将为大家输出更多高质量的实用文章!

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

标签: oracle建立索引
相关信息推荐
2022-08-13 17:51:52 
摘要:mysql进制转换方法:1、利用“bin(值)”,可将十进制转为二进制;2、利用“oct(值)”,可将十进制转为八进制;3、利用“hex(值)”,可将十进制转为十六进制;4、利用“conv('值',2,10)”,可将二进制转为十进制。
2022-10-19 17:30:16 
摘要:mysql查询为什么会慢,关于这个问题,在实际开发经常会遇到,而面试中,也是个高频题。遇到这种问题,我们一般也会想到是因为索引。那除开索引之外,还有哪些因素会导致数据库查询变慢呢?
2022-10-18 17:21:21 
摘要:本篇文章给大家带来了关于mysql的相关知识,其中主要整理了约束的相关问题,约束为了保证数据的完整性,数据完整性是指数据的精确性和可靠性,它是防止数据库中存在不符合语义规定的数据和防止因错误信息的输入输出造成无效操作或错误信息而提出的,下面一起来看一下,希望对大家有帮助。
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部