Oracle数据库中的自增主键

Posted

技术标签:

【中文标题】Oracle数据库中的自增主键【英文标题】:Autoincrement Primary key in Oracle database 【发布时间】:2011-02-05 01:03:33 【问题描述】:

我想在 ala SQL Server 列中实现标识或自动递增值:

CREATE TABLE RollingStock
( 
      Id NUMBER IDENTITY(1,1),
      Name Varchar2(80) NOT NULL      
);

如何做到这一点?

【问题讨论】:

***.com/questions/317001/autoincrement-in-oracle的可能重复 【参考方案1】:

正如 Orbman 所说,执行此操作的标准方法是使用序列。大多数人也会做的是将其与插入触发器结合使用。因此,当插入没有 ID 的行时,触发器会触发以从序列中为您填写 ID。

CREATE SEQUENCE SEQ_ROLLINGSTOCK_ID START WITH 1 INCREMENT BY 1 NOCYCLE;

CREATE OR REPLACE TRIGGER BI_ROLLINGSTOCK
BEFORE INSERT ON ROLLINGSTOCK
REFERENCING OLD AS OLD NEW AS NEW
FOR EACH ROW
 WHEN (NEW.ID IS NULL)
BEGIN
  select SEQ_ROLLINGSTOCK_ID.NEXTVAL
   INTO :NEW.ID from dual;
END;

这是在 Oracle 中使用触发器有意义的少数情况之一。

【讨论】:

请注意,触发器并非完全必要。只要每当执行插入时,使用序列中的值就可以了。它不是自动的,但也不需要太多的纪律。出于个人喜好,我极力避免触发因素。 @Adam,我完全同意。这是我将使用触发器的少数几个地方之一,主要是由于我所管理的数据库中严重缺乏命名标准,因此几乎不可能知道要使用的正确顺序。【参考方案2】:

如果您真的不在乎主键包含什么,您可以使用 RAW 类型作为主键列,该列包含系统生成的二进制形式的 guid。

CREATE TABLE RollingStock 
(  
  ID RAW(16) DEFAULT SYS_GUID() PRIMARY KEY, 
  NAME VARCHAR2(80 CHAR) NOT NULL       
); 

【讨论】:

以上是关于Oracle数据库中的自增主键的主要内容,如果未能解决你的问题,请参考以下文章

oracle 实现 自增主键功能

SQL Server 2000中如何设置自增主键?

oracle数据库,表中有id(自增字段,主键), insert 语句插入一条记录后要求,返回当前插入记录的id値。

Oracle自增主键的添加[sequence]--表数据已存在

Ef DbMigration 非主键字段 怎么设置为自增

Oracle间接实现自增主键