oracle并行添加索引

1.添加索引开8个并行,重新对数据进行排列 :

create index indexname on tablemane(to_char(字段,'yyyy-mm-dd')) online parallel 8

tablespace tablespace

pctfree 10

initrans 2

maxtrans 255

storage

(

initial 64K

next 1M

minextents 1

maxextents unlimited

);

--indexname索引名

--tablename添加索引的表

--parallel 并行数

--tablespace表空间名

2.结束并行

alter index indexnamenoparallel;

3.然后执行表信息收集使索引生效

exec dbms_stats.gather_table_stats(ownname=>'用户名',tabname=>'表名',estimate_percent=>30,cascade=>true);

-----------------------------------------------------------------------------------------------------

3.1如果进行表信息收集时造成锁表,一般缩表信息为

ORA-20005: object statistics are locked (stattype = ALL)

ORA-06512: 在 "SYS.DBMS_STATS", line 24281

ORA-06512: 在 "SYS.DBMS_STATS", line 24332

ORA-06512: 在 line 2

该锁表模式share。以下为缩表模式:

EXLUSIVE排他锁

        表级锁:当一个Session获取到了排他锁以后,其他用户只能进行查询操作,一般对一张表进行drop操作时获得该锁。

SHARE共享锁

        表级锁:SHARE模式允许并发查询,但是一个Session如果获得了共享锁,那么就不能对该表进行update操作。

ROW SHARE行共享模式

        行级锁:允许并发访问,但是不允许用户独占式访问。这个锁模式等价于WITH SHARE UPDATE(以前老版本的写法)

ROW EXCLUSIVE行排他模式

        行级锁:ROW EXCLUSIVE模式一般来说用户不会手动进行设置,在一个Session会话对数据库进行insert、update以及delete操作时,该用户就会自动的获取到这个ROW EXCLUSIVE锁。在ROW EXCLUSIVE和ROW SHARE模式一样,但是如果一个Session获得了ROW EXCLUSIVE锁,那么另外的Session就不能进行ROW EXCLUSIVE锁定,也不能对该表进行SHARE锁定。

SHARE ROW EXLUSIVE共享行排他

        行级锁:如果一个Session获取了SHARE ROW EXLUSIVE锁,该用户以及其他用户可以对整张表进行查询,但是,不允许其他用户对该表进行SHARE锁定或者更新表的数据。

3.2解锁

执行:EXEC DBMS_STATS.unlock_schema_stats(OWNNAME = 'HDM') 进行解锁

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答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数据库添加索引是一种优化数据库性能的方法,通过创建适当类型的索引来提高查询效率和数据检索速度。但需要根据实际情况进行选择,避免过多索引造成资源浪费,并定期对索引进行维护和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值