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数据库,表中有id(自增字段,主键), insert 语句插入一条记录后要求,返回当前插入记录的id値。