[SQL系列] 从头开始学PostgreSQL 自增 权限和时间
在PostgreSQL中,创建一个包含自增ID、权限字段和时间戳的表可以使用以下SQL语句:
CREATE TABLE example_table (
id SERIAL PRIMARY KEY,
permission VARCHAR(50) NOT NULL,
created_at TIMESTAMP WITH TIME ZONE DEFAULT CURRENT_TIMESTAMP
);
在这个例子中:
id
是一个自增的序列(SERIAL),作为主键。permission
是一个存储权限名称的VARCHAR字段,不能为空。created_at
是一个TIMESTAMP字段,会自动记录行被插入时的时间。
请注意,PostgreSQL中没有直接的TIMESTAMP WITH TIME ZONE
类型,但是可以使用timestamp
类型加上时区设置来达到相似的效果。
如果你的PostgreSQL版本不支持SERIAL
关键字,你可以使用CREATE SEQUENCE
来创建序列,并使用nextval
和currval
函数来获取序列的下一个值和当前值。
CREATE SEQUENCE example_table_id_seq;
CREATE TABLE example_table (
id INT PRIMARY KEY DEFAULT nextval('example_table_id_seq'),
permission VARCHAR(50) NOT NULL,
created_at TIMESTAMP WITH TIME ZONE DEFAULT CURRENT_TIMESTAMP
);
在这个例子中,我们创建了一个序列example_table_id_seq
,并在表的id
字段中使用它来自动生成唯一的ID。
评论已关闭