>데이터 베이스 >MySQL 튜토리얼 >oracle 学习笔记(十二) oracle独有对象 序列sequence

oracle 学习笔记(十二) oracle独有对象 序列sequence

WBOY
WBOY원래의
2016-06-07 15:30:441048검색

在多用户修改表时,可能面临这样的问题: 当前有字段id ,从1 到100 ; 如果用户a,b 同时想插入数据 , 使用max 得到表的最大100后, 都插入了id为101的数据. 这样表中就有两个id为101的数据了. 要想解决此问题, 必须将查询max 和插入数据放到同一语句中执行, 才能

在多用户修改表时,可能面临这样的问题:

   当前有字段id ,从1 到100 ; 如果用户a,b 同时想插入数据 , 使用max 得到表的最大值100后, 都插入了id为101的数据. 这样表中就有两个id为101的数据了. 

   要想解决此问题, 必须将查询max 和插入数据放到同一语句中执行, 才能在多线程时避免公用区出现的问题.


   oracle 中 可采用sequence 对象来解决这个问题 .

  create sequence seq; 

  

多次使用

  select  seq.nextval from dual ;

   可以发现结果是递增的.


  当多个用户同时使用时也不会产生重复的数据 .

 

 例如向article 表中插入数据:  

     insert   into article  values (seq.nextval,'a','b');

 insert   into article  values (seq.nextval,'a','b');

 insert   into article  values (seq.nextval,'a','b');

 insert   into article  values (seq.nextval,'a','b');

..............

 插入的 在id 字段上的seq.nextval 是递增不重复的.



    

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.