Oracle 实现类似SQL Server中自增字段的一个办法

 更新时间:2009年07月30日 18:45:54   作者:  
由于Oracle中没有类似SQL Server中的自增字段,所以我们如果想要通过设定类似ID性质的唯一列的话,需要借助Oracle的sequence,先建立一个序列,然后在每次插入数据的时候,通过前触发器来更新ID值,并将序列的序号加1,这样的迂回方式来实现。
相关代码如下:
1. 创建sequence:
复制代码 代码如下:

CREATE SEQUENCE SEQU_DATA_DATAINFO INCREMENT BY 1 START WITH 1 NOCYCLE NOCACHE NOORDER;

2. 创建触发器:
复制代码 代码如下:

create or replace TRIGGER TRIG_TEST
BEFORE INSERT ON TABLE1
FOR EACH ROW
DECLARE
tmpVar NUMBER;
BEGIN
tmpVar := 0;
Select SEQU_PROC_ASSOCIATEINFO.NextVal into tmpVar from dual;
:new.procid:=tmpVar;
EXCEPTION
WHEN OTHERS THEN
-- Consider logging the error and then re-raise
RAISE;
END;

相关文章

  • Oracle数据库如何更改数据文件位置

    Oracle数据库如何更改数据文件位置

    这篇文章主要给大家介绍了关于Oracle数据库如何更改数据文件位置的相关资料,Oracle数据库的数据文件的位置和信息都被记录在控制文件中,需要的朋友可以参考下
    2023-08-08
  • ORACLE常见错误代码的分析与解决(一)

    ORACLE常见错误代码的分析与解决(一)

    ORACLE常见错误代码的分析与解决(一)...
    2007-03-03
  • Oracle中SQL*plus常用命令详解

    Oracle中SQL*plus常用命令详解

    在 Oracle 11g 数据库系统中,用户对数据库的操作主要是通过 SQL*Plus 来完成的,下面将介绍如何启动 SQL*Plus 和如何使用 SQL*Plus 连接到数据库,感兴趣的朋友跟随小编一起看看吧
    2024-01-01
  • 关于expdp任务异常的处理案例详析

    关于expdp任务异常的处理案例详析

    这篇文章主要给大家介绍了关于expdp任务异常处理的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • oracle 11g的警告日志和监听日志的删除方法

    oracle 11g的警告日志和监听日志的删除方法

    这篇文章主要介绍了oracle 11g的警告日志和监听日志的删除方法,需要的朋友可以参考下
    2014-07-07
  • ORACLE数据库中Rownum用法详解

    ORACLE数据库中Rownum用法详解

    这篇文章主要介绍了ORACLE数据库中ROWNUM用法详解,对于rownum来说它是oracle系统顺序分配为从查询返回的行的编号,且rownum不能以任何表的名称作为前缀,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • Oracle统计信息的导出导入测试示例详解

    Oracle统计信息的导出导入测试示例详解

    这篇文章主要给大家介绍了关于Oracle统计信息的导出导入测试的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-12-12
  • oracle net manager 数据传输安全步骤详解

    oracle net manager 数据传输安全步骤详解

    oracle net manager来加密客户端与数据库之间或中间件与 数据库之间的网络传输数据。这篇文章主要介绍了oracle net manager 数据传输安全 ,需要的朋友可以参考下
    2018-09-09
  • ORACLE中%TYPE和%ROWTYPE的使用详解

    ORACLE中%TYPE和%ROWTYPE的使用详解

    这篇文章主要介绍了ORACLE中%TYPE和%ROWTYPE的使用,本文给大家讲解的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-11-11
  • oracle中where 子句和having子句中的区别介绍

    oracle中where 子句和having子句中的区别介绍

    这篇文章主要介绍了在oracle中where 子句和having子句中的区别,本文通过sql语句给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-12-12

最新评论