• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Oracle 12C -- sequence的新特性

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

如果使用了全局临时表和sequence,有时会遇到一些问题。因为全局临时表与会话(或会话中的事务)相关,而sequence与数据库级别相关。

在12C中,可以创建一个sequence,其使用范围只是针对一个给定的session。

 

--当全局临时表gtt在某个会话中被清空时(如commit),sequence的值不会被重置。下次调用该sequence会使用其nextval值。

SQL> connect scott/tiger
SQL> drop table gtt;
SQL> create global temporary table gtt(id number,seq_number number);
SQL> grant all on gtt to tiger;
SQL> drop sequence seq_session;
SQL> create sequence seq_session start with 1 session;
SQL> grant all on seq_session to tiger;
SQL> insert into gtt values(1,seq_session.nextval);
SQL> insert into gtt values(2,seq_session.nextval);
SQL> select * from scott.gtt;

        ID SEQ_NUMBER
---------- ----------
         1          1
         2          2

SQL> 
commit;
SQL> select * from scott.gtt;

no rows selected

SQL> 
insert into gtt values(1,seq_session.nextval);
insert into gtt values(2,seq_session.nextval);
SQL> select * from scott.gtt;

        ID SEQ_NUMBER
---------- ----------
         1          3
         2          4

SQL> 

继续测试。
--会话结束,sequence的值会被重置

SQL>conn tiger/tiger
SQL>drop synonym gtt;
SQL>drop synonym seq_session;
SQL>create synonym gtt for scott.gtt;
SQL>create synonym seq_session for scott.seq_session;
SQL> select * from gtt;

no rows selected

SQL>
SQL> insert into gtt values(1,seq_session.nextval);
SQL> insert into gtt values(2,seq_session.nextval);
--在11g中,这里查询结果是5,6 SQL
> select * from gtt; ID SEQ_NUMBER ---------- ---------- 1 1 2 2 SQL> SQL> commit; SQL> select * from gtt; no rows selected SQL> SQL> conn scott/tiger SQL> insert into gtt values(1,seq_session.nextval); SQL> insert into gtt values(2,seq_session.nextval);
--在11g中,这里查询结果是7,8 SQL
> select * from gtt; ID SEQ_NUMBER ---------- ---------- 1 1 2 2 SQL>

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
[C++ Primer] : 第16章: 模板与泛型编程发布时间:2022-07-13
下一篇:
c++中如何将类智能通过静态分配,只能通过动态分配;发布时间:2022-07-13
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap