db2 创建表自增主键
时间: 2023-08-01 15:06:50 浏览: 311
在 DB2 中,可以通过定义带有 IDENTITY 属性的列来实现自增主键。IDENTITY 是 DB2 中的关键字,用于定义自增列。创建自增主键的方法如下:
```sql
CREATE TABLE table_name (
id INTEGER GENERATED ALWAYS AS IDENTITY (START WITH 1, INCREMENT BY 1) PRIMARY KEY,
column1 datatype1,
column2 datatype2,
...
);
```
在上面的语句中,`id` 列被定义为自增主键列。`GENERATED ALWAYS AS IDENTITY` 表示该列是自动生成的,并且使用 `START WITH` 和 `INCREMENT BY` 子句定义了自增列的起始值和步长。`PRIMARY KEY` 关键字指定了该列为主键。
需要注意的是,自增主键列必须是表中的唯一列,因此必须将其定义为主键。此外,自增主键列只能是整数类型,如 INTEGER 或 BIGINT。
创建表时,也可以使用 `ALTER TABLE` 命令来添加自增主键列:
```sql
ALTER TABLE table_name ADD COLUMN id INTEGER GENERATED ALWAYS AS IDENTITY (START WITH 1, INCREMENT BY 1) PRIMARY KEY;
```
以上是在 DB2 中创建表自增主键的方法。
相关问题
DB2数据库设置自增主键
DB2数据库中设置自增主键通常是通过创建一个自动递增的序列或生成列来实现的。以下是基本步骤:
1. **创建表时指定为主键**:
当你创建一个新的表时,可以在`id`这样的字段上使用关键字`GENERATED BY DEFAULT AS IDENTITY` 或 `IDENTITY`。例如:
```sql
CREATE TABLE my_table (
id INT GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY,
... 其他字段 ...
);
```
2. **自动递增属性**:
如果已经有一个表存在,并且你想让它支持自增长主键,你可以使用ALTER TABLE命令添加一个序列或生成列:
```sql
ALTER TABLE my_table ADD COLUMN id INT GENERATED ALWAYS AS IDENTITY (START WITH 1 INCREMENT BY 1);
```
这里`INCREMENT BY 1`表示每次增加1,`START WITH`指定了初始值。
3. **事务提交保证**:
自增ID通常是在插入新行时由数据库自动更新的。在并发环境中,为了防止数据冲突,可能需要配置合适的锁策略或者事务隔离级别。
4. **查询生成的ID**:
插入记录后,如果想查看刚插入的ID,可以直接查询新行,因为它是自动产生的。
db2 表新增一个自增主键
在DB2数据库中,如果你想为一个新的表添加一个自动递增的主键(通常称为"序列"或"identity"),你可以按照以下步骤操作:
1. **创建表时指定**:
使用SQL创建表时,可以在`id`或其他合适的字段上加上`auto increment`或`IDENTITY`关键字。例如,如果你正在创建名为`users`的表,可以这样写:
```sql
CREATE TABLE users (
id INT GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY,
name VARCHAR(50),
email VARCHAR(100)
);
```
这里`id`字段会自动增加,每次插入新行时。
2. **如果表已经存在**:
如果表已经存在且你想在现有基础上添加主键,可以使用`ALTER TABLE`命令追加`IDENTITY`列:
```sql
ALTER TABLE users ADD COLUMN id INT GENERATED BY DEFAULT AS IDENTITY;
```
这将为`id`字段创建一个新的、自动递增的主键。
记住,DB2有多种方言,语法可能会略有差异,上述例子适用于标准的SQL-92风格。在实际操作前,建议查阅你的DB2文档确认具体的语法。
阅读全文