1,序列创建很快
单纯的nextval()在普通PC上都可以达到7万的tps,相比其他操作,创建序列本身要快的多,所以不大可能成为系统性能的瓶颈
2,序列的cache优化效果不大
因为序列创建不是性能瓶颈所以也看不出cache的优化效果。序列cache后可能会导致序列的不连续,所以除非真的需要,否则不必cache。
5. 补充
序列既然提供了cache,想必对性能还是有用处的。参考网友对Oracle的测试,使用cache 50和不使用cache,处理时间居然差了100多倍。
http://blog.itpub.net/751051/viewspace-731760/
但在PostgreSQL上进行类似的带序列的批量插入的测试,cache的性能提高仍然不明显。是不是PG对序列的优化做的太好了,都不需要那种牺牲序列连续性的序列cache上场了?
-
postgres=# insert into tb1 select 1 from (select generate_series(1,100000))tbx;
-
INSERT 0 100000
-
Time: 145.642 ms
-
postgres=# insert into tb1 select 1 from (select generate_series(1,100000))tbx;
-
INSERT 0 100000
-
Time: 156.057 ms
-
postgres=# insert into tb1 select 1 from (select generate_series(1,100000))tbx;
-
INSERT 0 100000
-
Time: 172.874 ms
-
postgres=# insert into tb1 select nextval(‘seq1‘) from (select generate_series(1,100000))tbx;
-
INSERT 0 100000
-
Time: 184.046 ms
-
postgres=# insert into tb1 select nextval(‘seq1‘) from (select generate_series(1,100000))tbx;
-
INSERT 0 100000
-
Time: 183.670 ms
-
postgres=# insert into tb1 select nextval(‘seq1‘) from (select generate_series(1,100000))tbx;
-
INSERT 0 100000
-
Time: 183.410 ms
-
postgres=# insert into tb1 select nextval(‘cached_seq‘) from (select generate_series(1,100000))tbx;
-
INSERT 0 100000
-
Time: 181.197 ms
-
postgres=# insert into tb1 select nextval(‘cached_seq‘) from (select generate_series(1,100000))tbx;
-
INSERT 0 100000
-
Time: 144.633 ms
-
postgres=# insert into tb1 select nextval(‘cached_seq‘) from (select generate_series(1,100000))tbx;
-
INSERT 0 100000
-
Time: 198.545 ms