oracle联合主键效率,Oracle主键与复合主键的性能分析

实验表明,Oracle中主键与复合主键在查询性能上相同,但复合主键在插入和更新时由于使用更多块创建索引,性能较低。在正确使用索引的情况下,两者查询效率一致。
摘要由CSDN通过智能技术生成

总结:

1、主键和复合主键,查询性能相同(索引高度相同,恰当的运用索引)。

2、主键和复合主键,(update,insert)性能不同(因为复合主键会用更多的块来创建索引,所以update,insert性能低)

实验思路:

1、 建立实验表,及主键,联合2个主键,联合3个主键

2、 查看索引的结构

3、查看条件相同的,执行计划(来确定主键和复合主键的效率)

一、建立实验表;test1为单主键为1个column,test2为联合主键2个columns,test3为联合主键3个columns

SQL> create table test1(a number,b number,c number,primary key(a));

Table created.

SQL> create table test2(a number,b number,c number,primary key(a,b));

Table created.

SQL> create table test3(a number,b number,c number,primary key(a,b,c));

Table created.

二、查看索引的结构

1、先查看一下建立的表对应的索引

SQL> select index_name,table_name from user_indexes;

INDEX_NAME                    TABLE_NAME

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

SYS_C005198                   TEST1

SYS_C005199                   TEST2

SYS_C005200                   TEST3

2、写个储存过程来给实验表插入数据

begin

for i in 1..10000 loop

insert into test1 values(i,i+1,i+2);

commit;

end loop;

end;

Test1

SQL>analyzeindex SYS_C005198 validate structure;

Index analyzed.

SQL> select HEIGHT,BLOCKS,BR_BLKS,LF_BLKS,LF_ROWS,DEL_LF_ROWS from index_stats ;

HEIGHT    BLO

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值