当前位置:首页 > 行业动态 > 正文

plsql设置主键自增

在PL/SQL中,设置主键自增可以使用以下语句:,,“ sql,ALTER TABLE 表名,ADD (主键列名 NUMBER(10) GENERATED ALWAYS AS IDENTITY,,CONSTRAINT 主键约束名 PRIMARY KEY (主键列名));,“

在PL/SQL中,设置主键自增可以通过以下步骤实现:

plsql设置主键自增  第1张

1、创建表时设置主键自增

2、修改已有表的主键自增

下面分别介绍这两种情况的具体操作。

创建表时设置主键自增

1、使用CREATE TABLE语句创建表,并设置主键字段为自增,创建一个名为employees的表,其中id为主键,且自动递增:

CREATE TABLE employees (
  id NUMBER(10) PRIMARY KEY GENERATED ALWAYS AS IDENTITY,
  name VARCHAR2(50),
  age NUMBER(3),
  department_id NUMBER(10)
); 

2、插入数据时,不需要为主键字段赋值,数据库会自动为其分配一个递增的值,插入一条员工记录:

INSERT INTO employees (name, age, department_id) VALUES ('张三', 25, 1001); 

修改已有表的主键自增

1、如果已经创建了表,但未设置主键自增,可以使用ALTER TABLE语句修改表结构,将主键字段设置为自增,将employees表中的id字段设置为自增:

ALTER TABLE employees MODIFY id NUMBER(10) PRIMARY KEY GENERATED ALWAYS AS IDENTITY; 

2、如果表中已经有数据,需要先删除表中的数据,然后再执行上述ALTER TABLE语句,因为一旦设置了主键自增,之前插入的数据可能会与新的主键冲突,删除employees表中的所有数据:

DELETE FROM employees; 

3、再次执行ALTER TABLE语句,将主键字段设置为自增:

ALTER TABLE employees MODIFY id NUMBER(10) PRIMARY KEY GENERATED ALWAYS AS IDENTITY; 

4、现在可以重新插入数据,数据库会自动为主键字段分配递增的值。

0