- 浏览: 468214 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
yuan_bin1990:
您好,请问下demo如何运行啊,准备研究研究,但不知道入口啊。 ...
ssh2(struts2+spring2.5+hibernate3.3)自动生成代码程序 -
luyulong:
[b][/b][i][/i][ ...
jQuery进度条插件 jQuery progressBar -
txin0814:
mark..
读取文件目录 -
vurses:
[align=center][color=red][size= ...
include 与 jsp:include区别 -
Roshan2:
http://lijiejava.iteye.com/blog ...
Spring AOP 入门实例
一、索引
索引和对应的表应该位于不同的表空间中(primary key (id) using index tablespace mytable_index),oracle能够并行读取位于不同硬盘上的数据,可以避免产生I/O冲突 。
B树索引:在B树的叶节点中存储索引字段的值与ROWID。唯一索引和不唯一索引都只是针对B树索引而言。 Oracle最多允许包含32个字段的复合索引。
1.索引的创建方法
(1)*Tree索引
Create index indexname on tablename(columnname[columnname...])
(2)反向索引
Create index indexname on tablename(columnname[columnname...]) reverse
(3)降序索引
Create index indexname on tablename(columnname DESC[columnname...])
(4)位图索引
Create BITMAP index indexname on tablename(columnname[columnname...])
(5)函数索引
Create index indexname on tablename(functionname(columnname))
注意:创建索引后分析要索引才能起作用。
analyze index indexname compute statistics;
2.索引创建策略
(1).导入数据后再创建索引
(2).不需要为很小的表创建索引
(3).对于取值范围很小的字段(比如性别字段)应当建立位图索引
(4).限制表中的索引的数目
(5).为索引设置合适的PCTFREE值
(6).存储索引的表空间最好单独设定
3.索引使用场合及建议
(1)B*Tree索引
常规索引,多用于oltp系统,快速定位行,应建立于高cardinality列(即列的唯一值除以行数为一个很大的值,存在很少的相同值)。
(2)反向索引
B*Tree的衍生产物,应用于特殊场合,在ops环境加序列增加的列上建立,不适合做区域扫描。
(3)降序索引
B*Tree的衍生产物,应用于有降序排列的搜索语句中,索引中储存了降序排列的索引码,提供了快速的降序搜索。
(4)位图索引
位图方式管理的索引,适用于OLAP(在线分析)和DSS(决策处理)系统,应建立于低cardinality列,适合集中读取,不适合插入和修改,提供比B*Tree索引更节省的空间。
(5)函数索引
B*Tree的衍生产物,应用于查询语句条件列上包含函数的情况,索引中储存了经过函数计算的索引码值。可以在不修改应用程序的基础上能提高查询效率。
4.索引例
创建不唯一索引
create index emp_ename on employees(ename) tablespace users storage(......) pctfree 0;
创建唯一索引
create unique index emp_email on employees(email) tablespace users;
创建位图索引
create bitmap index emp_sex on employees(sex) tablespace users;
创建反序索引
create unique index order_reinx on orders(order_num,order_date) tablespace users reverse;
创建函数索引(函数索引即可以是普通的B树索引,也可以是位图索引)
create index emp_substr_empno on employees(substr(empno,1,2)) tablespace users;
修改索引存储参数(与表类似,INITIAL和MINEXTENTS参数在索引建立以后不能再改变)
alter index emp_ename storage(pctincrease 50);
由于定义约束时由oracle自动建立的索引通常是不知道名称的,对这类索引的修改经常是利用alter table ..using index语句进行的,而不是alter index语句
利用下面的语句将employees表中primary key约束对应的索引的PCTFREE参数修改为5
alter table employees enable primary key using index pctfree 5;
5.清理索引碎片
(1).合并索引(只是简单的将B树叶结点中的存储碎片合并在一起,并不会改变索引的物理组织结构)
alter index emp_pk coalesce;
(2).重建索引(不仅能够消除存储碎片,还可以改变索引的全部存储参数设置,并且可以将索引移动到其它的表空间中,重建索引
实际上就是再指定的表空间中重新建立一个新的索引,然后删除原来的索引)
alter index emp_pk rebuild;
6.删除索引
drop index emp_ename;
如果索引中包含损坏的数据块,或者包含过多的存储碎片,需要首先删除这个索引,然后再重建它.
如果索引是在创建约束时由oracle自动产生的,可以通过禁用约束或删除约束的方法来删除对应的索引.
在删除一个表时,oracle会自动删除所有与该表相关的索引.
7.索引数据字典
all_indexes/dba_indexes/user_indexes 索引的基本信息
all_ind_columns/dba_ind_columns/user_ind_columns 索引对应的字段信息
二、序列(Sequence)
序列是一数据库对象,利用它可生成唯一的整数。一般使用序列自动地生成主键值。
(1) 建立序列命令
CREATE SEQUENCE [user.]sequence_name
[increment by n]
[start with n]
[maxvalue n | nomaxvalue]
[minvalue n | nominvalue];
[NOCYCLE] --
INCREMENT BY: 指定序列号之间的间隔,该值可为正的或负的整数,但不可为0。序列为升序。忽略该子句时,缺省值为1。
START WITH:指定生成的第一个序列号。在升序时,序列可从比最小值大的值开始,缺省值为序列的最小值。对于降序,序列可由比最大值小的值开始,缺省值为序列的最大值。
MAXVALUE:指定序列可生成的最大值。
NOMAXVALUE:为升序指定最大值为1027,为降序指定最大值为-1。
MINVALUE:指定序列的最小值。
NOMINVALUE:为升序指定最小值为1。为降序指定最小值为-1026。
NOCYCLE:一直累加,不循环
(2)更改序列命令
ALTERSEQUENCE [user.]sequence_name
[INCREMENT BY n]
[MAXVALUE n| NOMAXVALUE ]
[MINVALUE n | NOMINVALUE];
修改序列可以:
修改未来序列值的增量。
设置或撤消最小值或最大值。
改变缓冲序列的数目。
指定序列号是否是有序。
(3)删除序列命令
DROP SEQUENCE [user.]sequence_name;
用于从数据库中删除一序列。
例子:
- create sequence NCME_QUESTION_SEQ
- minvalue 1 maxvalue 999999999999 start with 1 increment by 1 nocache;
发表评论
-
oracle 恢复误删除的表和误更新的表
2010-09-14 16:08 1851今天不小心把一个表删除了。呵呵 查找了下恢复的 ... -
oracle 表恢复
2010-09-14 15:56 1112在Oracle中可能不小心会DROP掉一个表,如果 ... -
eclipse, language:java; db:db2 ; dbDriver:jdbc(2)
2010-06-17 13:30 1726使用jdbc访问db2 1、 ecl ... -
Oracle常用及非常用函数
2010-06-16 21:47 848注:N表示数字型,C表 ... -
简单SQL 性能的优化
2010-06-16 21:27 7291.1 IN 操作符 用IN写 ... -
oracle提高查询效率
2010-06-16 21:25 879(1) 选择最有效率的表名顺序(只在基于规则的优化器中有效): ... -
oracle查询/子查询/复制表和数据
2010-06-16 21:24 1526一、连接查询 1.内连接 内连接用于返回满足连接条件的 ... -
Oracle数据导入导出imp/exp命令和grant命令
2010-06-16 21:18 2078一、数据导入导出命令 Oracle数据导入导出imp/e ... -
Oracle格式化函数
2010-06-16 21:18 1384格式化函数 函数 返回类型 描述 例 ... -
oracle 统计/分析函数
2010-06-16 21:12 1130Oracle从8.1.6开始提供分析函数,分析函数用于计 ... -
oracle blob数据存取
2010-06-16 21:09 1092Oracle中的lob (Large Object)可以存储非 ... -
java oracle clob
2010-06-16 21:09 1177Sql代码 create table TE ... -
Oracle常见的问题总结
2010-06-16 20:40 958SQL语句 1. 获取有哪些用户在使用数据库 se ... -
Oracle函数大全
2010-06-12 17:31 705SQL 中的单记录函数1.ASCII 返回与指定的字符对应的十 ... -
Toad 9.7.2注册码
2009-12-03 21:49 2951TOAD的无限期注册码:5-88860-02883-29060 ... -
oracle导入导出命令详解
2009-11-06 10:29 1305ORACLE EXP/IMP 参数详解2008-01-09 1 ... -
好多常用oracle函数
2009-11-06 10:15 979·········10········20········30 ... -
12514 和12541的错误
2009-10-25 22:07 8491.CMD下执行lsnrctl start 2.CMD下执行 ... -
30个Oracle语句优化规则详解
2009-09-02 22:22 6361.选用适合的Oracle优化 ... -
Oracle公司内部数据库培训资料
2009-08-04 13:21 1162Oracle公司内部数据库培训资料
相关推荐
### 一、Oracle索引 索引在Oracle数据库中的作用类似于图书的目录或索引页,它能够加快数据的检索速度,特别是在处理大量数据时,索引的存在可以显著减少查询时间。在实验中,通过`CREATE INDEX`语句创建了两个索引...
Oracle 实验报告 - 索引、视图、序列和同义词的创建 本实验报告旨在介绍 Oracle 中的索引、视图、序列和同义词的概念和应用。通过实验,掌握创建索引、视图、序列和同义词的命令,并理解它们在数据库中的作用。 一...
### Oracle索引类型详解 #### 一、B\*Tree索引:数据检索的基石 在Oracle数据库中,B\*Tree索引是最常见的索引结构,也是默认创建的索引类型。它基于二叉树原理,由分支块(branch block)和叶块(leaf block)构成,...
在第13讲中,我们重点关注了四个核心概念:视图、索引、序列和同义词,这些都是数据库管理和优化的重要工具。 1. 视图(View) 视图是数据库中的一个虚拟表,它是由SQL SELECT语句定义的,基于一个或多个实际表(或...
oracle索引序列查询分组排序连接视图等PPT教案.pptx
通过以上详细介绍,我们可以看出索引、序列和同义词都是Oracle数据库中非常重要的对象,它们各自承担着不同的功能与职责,共同促进了数据库性能的提升和管理的便捷性。在实际应用中,合理地设计和使用这些对象能够...
以上是Oracle数据库中创建表、索引、表空间、触发器、用户和序列的基本操作。在实际应用中,根据业务需求可能还需要考虑其他因素,如分区、约束、存储过程、视图等。掌握这些基本操作对于理解和管理Oracle数据库至关...
在Oracle数据库管理系统中,创建表和唯一索引是数据库设计中的关键步骤,它们对于数据的组织、查询效率和数据完整性至关重要。以下将详细介绍如何创建学员信息表,创建唯一索引,以及如何修改表来添加主键和检查约束...
本文将详细探讨四个关键概念:索引、视图、同义词和序列。 首先,索引是提升查询性能的关键工具。它们为表的特定列提供额外的数据结构,允许数据库更快地定位和检索数据。创建索引分为两种主要方式:企业管理器和...
在Oracle数据库管理中,索引序列的创建是优化查询性能、确保数据完整性的关键操作之一。根据提供的文件信息,我们将深入探讨与“索引序列的创建”相关的几个核心知识点,包括用户管理、表结构设计、索引创建及管理、...
在Oracle数据库管理中,经常会遇到创建表、索引、序列以及修改表列等操作,这些是数据库维护的基础工作。为了提高工作效率,将这些常见的数据库操作进行封装,形成可复用的PL/SQL包是非常必要的。这里我们将探讨如何...
与`INSERT INTO SELECT`类似,`CTAS`可以快速创建一个与源表结构相同的新表,并填充数据。然而,`CTAS`不会影响原有表,它创建的是一个全新的实体。如果`table2`已经存在,`CTAS`会失败,除非你添加`OR REPLACE`选项...
Oracle数据库的SQL开发教程涵盖了广泛的主题,其中包括序列、索引和同义词这些重要的数据库对象。在本章中,我们将深入探讨这些概念及其在数据库管理中的应用。 **序列(SEQUENCE)**是Oracle数据库中用于生成唯一...
oracle笔记其它数据库对象(序列、索引、同义词),有创建序列,创建索引,创建同义词的具体代码案例
总的来说,Oracle数据库中的锁、序列和索引管理是保证数据一致性和优化查询性能的核心要素。理解这些概念并熟练掌握其使用,对于任何Oracle数据库管理员来说都是至关重要的。通过适当配置和管理,可以确保数据库在多...
提供了一个Oracle数据库建表语句的完整示例代码,用于演示如何在Oracle环境中创建一个结构化的数据表。 资源优点: 完整性展示:DEMO提供了从基础建表到复杂约束(如外键、自增主键)等实际生产场景所需的完整SQL...
在Oracle数据库管理中,实验3涉及到了几个关键的数据库对象:视图、序列、同义词和索引。这些元素是构建和管理高效数据库系统的重要组成部分。以下是它们的详细解释和示例: 1. **视图(View)**: 视图是从一个或...
#### 索引(Index)在Oracle中的应用与维护 索引是加速数据检索的数据库结构,通过建立数据项的快速查找路径,可以显著提升查询效率。 - **索引类型**:包括B树索引、位图索引、倒排索引等。其中,B树索引是最常用...
### Oracle索引、视图、序列与同义词实验知识点详解 #### 一、Oracle索引的创建与管理 **1.1 创建普通索引** - **实验目标**:掌握如何在Oracle数据库中为特定列创建索引。 - **实验步骤**:在SCOTT模式下,为`...