当前位置:   article > 正文

oracle guid 主键 排序,oracle uuid/GUID 主键与number主键比较

uuid主键排序

记录数:349408

共三个表:T2,T3,T4

T2的ID是RAW(16)

T3的ID是char(32)

T4的ID是Number

其它字段一样(连ID共22个字段):

X1 NUMBER

X2 NUMBER

X3 VARCHAR2(500 BYTE)

X4 VARCHAR2(2000 BYTE)

X5 VARCHAR2(500 BYTE)

X6 NUMBER

X7 DATE

X8 VARCHAR2(2000 BYTE)

X9 NUMBER

X10 NUMBER(1,0)

X11 NUMBER

X12 NUMBER

X13 VARCHAR2(50 BYTE)

X14 VARCHAR2(50 BYTE)

X15 VARCHAR2(2000 BYTE)

X16 VARCHAR2(256 BYTE)

X17 NUMBER(1,0)

X18 VARCHAR2(2000 BYTE)

X19 VARCHAR2(4000 BYTE)

X20 NUMBER

X21 NUMBER

测试一:

select * from T2;

select * from T3;

select * from T4;

结果(单位:秒)

1

2

3

4

5

6

平均

t2

12.71

10.05286

9.056

9.5318

9.077147

9.40745

9.972543

t3

9.309

9.9791

8.913

9.0849

9.789756

8.52539

9.266858

t4

8.9315

9.13159

8.873

9.0031

9.696671

8.8288

9.077444

测试二:

select count(*) from T2;

select count(*) from T3;

select count(*) from T4;

结果(单位:秒)

1

2

3

4

平均

t2

2.703

2.766

3.5

2.813

2.9455

t3

2.844

2.938

2.922

2.875

2.89475

t4

2.375

2.813

2.344

2.953

2.62125

结论:

select全表、select count

RAW(16) 性能最差

CHAR(32)中

NUMBER 最好

不过2.62与2.94、9.077与9.97也差不了多少。

UUID我是一定要用的,所以只能RAW(16)或CHAR(32),看起来select性能还能接受。

insert慢一点无所谓,也不delete。

CHAR(32)么,可读性好一点,编程稍微方便一点点

RAW(16)我想就占的空间是CHAR(32)的一半这点优势了吧

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/不正经/article/detail/475330
推荐阅读
相关标签
  

闽ICP备14008679号