首页 ┆ 网站地图 ┆ 在线留言 ┆ 游戏资讯 ┆ 资源下载 ┆ 端午节祝福 ┆ 迅雷在线影视 ┆淘宝手机在线充值 ┆淘宝游戏点卡充值 
设为首页
加入收藏
联系我们
高级搜索
您当前的位置: 主页>数据库>ORACLE>oracle自增序列sequence的使用详细介绍
oracle自增序列sequence的使用详细介绍
来源: 发布时间:2008-09-11 发布人: 浏览: 人次   字体: [ ]  

3、如何使用
         第一种方法:一般来说需要新建一个触发器(TRIGGER),使得在插入数据之前先运行Sequence生成自增号。
示例Trigger
CREATE OR REPLACE TRIGGER SCOTT.DMIFATTACH_TRG
BEFORE INSERT
ON SCOTT.DMIFATTACH
REFERENCING OLD AS OLD NEW AS NEW
FOR EACH ROW
begin
    select SCOTT.DMIFATTACHID.nextval into :new.ATTACHID from dual;
  end;
         第二种方法:可以在插入数据时直接调用。
          insert into table(id,name) values(seq_name.nextval,'名字');

         其它:对于hibernate来说,在插入数据之前会先运行一次Sequence生成id的,所以这时如果还有触发器(TRIGGER),又要再运行一次Sequence,于是就会发现id是以2为步进增加的。这时把Trigger删除,步进就为1了。
         如果使用hibernate则需要在hbm.xml文件中把ID的生成方式设为sequence.
    <id
        name="postid"
        type="java.lang.Integer"
        column="POSTID"
    >
        <meta attribute="field-description">
           @hibernate.id
            generator-class="sequence"
            type="java.lang.Integer"
            column="POSTID"
        </meta>
        <!--设置id生成方式-->
          <generator class="sequence">
            <param name="sequence">SCOTT.DMIFPOSTID</param>
         </generator>
    </id>
同时在调用this.getHibernateTemplate().save()方法时会自动生成根据sequence把查询到的id号set给这个对象的id.

要查看已创建的Sequence,执行的语句是:

SQL代码  select * from user_sequences;  
其中返回的SEQUENCE_NAME为序列名,LAST_NUMBER为当前值
要取得下一ID,可以使用:
SQL代码  select  序列名.nextval from 表名  
这个语句会返回多个序列号(会被缓存起来),要取得一个序号,表名使用dual(虚表)即可


共2页: 上一页 [1] 2 下一页
相 关 文 章   发布商链接
·Oracle数据库中时间问题的一些比较
·迁移ORACLE数据文件的几种常用方式
·ORACLE实现字符串截取的功能
·Oracle9i重命名机器名后不能启动的解...
·如何修改Oracle的默认端口8080?
·如何在Oracle数据库中创建表和视图?
·解析Oracle中限制返回结果集的大小
·用Oracle 10g列值掩码技术隐藏敏感数...
·Oracle巧取指定记录以及巧用外关联...
·ORACLE使用中的常见、实用的问题技巧
 §最新评论:(评论内容只代表网友观点,与本站立场无关!)
网名: 验证码:  【所有评论】【↑返回顶部
评 分: 12 345
评论内容:(不能超过500字,请自觉遵守互联网相关政策法规。[按 Ctrl+Enter 可直接提交]
注意:请勿在本站发布政治话题、色情及违反法律的内容。
IT知道网 声明:刊登此文章是为了传递更多信息,文章内容仅供参考,转载请注明出处。
推 荐 文 章
·Oracle数据库临时表的管理及...
·Oracle中to_date函数的详细使
·Oracle导致CPU进程100%原因及
·实例讲解对oracle进行简单树...
·Oracle服务费是如何计算的,以...
·如何完全清除Oracle
·ORACLE 10G分区表维护:全局...
·怎样有效提高Oracle 10G增量...
·Oracle数据库的四种启动方式...
·利用函数实现oracle行列转换
·使用type类型和存储过程来完...
·oracle9i客户端如何连接oracl...
·解决ORACLE被锁定的资源两法
·oracle中分割字符串,并求最...
·详细讲解Oracle数据库灾难防...
热 门 文 章
·Oracle内连接、外连接、右外...
·oracle分析函数row_number的...
·oracle9i客户端如何连接oracl...
·ORACLE使用中的常见、实用的...
·利用函数实现oracle行列转换
·ORACLE 10G分区表维护:全局...
·导入、导出oracle数据库与复...
·如何完全清除Oracle
·Oracle中to_date函数的详细使...
·ORACLE实现字符串截取的功能
·oracle中分割字符串,并求最...
·浅说利用pl/sql工具连接oracl...
·几个方面入手oracle性能优化...
·实例讲解对oracle进行简单树...
·如何在Oracle数据库中创建表...
网站首页 - 关于本站 - 加入收藏 - 网站地图 - 友情连接 - 在线留言 - 联系我们 - 返回顶部
Copyright © 2007 IT知道网.[冀ICP备07026896号]. All Rights Reserved .