- 使用序列作为主键:在创建表时,可以使用序列作为主键来保证主键的唯一性和自增性。例如:
CREATE TABLE employees (
employee_id SERIAL PRIMARY KEY,
first_name VARCHAR(50),
last_name VARCHAR(50)
);
- 使用序列值作为默认值:可以在创建表时为某一列设置默认值为序列值,这样在插入数据时如果不指定该列的值,就会自动使用序列生成的下一个值作为默认值。例如:
CREATE TABLE orders (
order_id SERIAL PRIMARY KEY,
order_date DATE DEFAULT CURRENT_DATE,
total_amount DECIMAL(10, 2) DEFAULT 0
);
- 手动获取序列值:除了在表定义中使用序列外,还可以通过
NEXTVAL
和CURRVAL
函数手动获取序列的下一个值和当前值。例如:
SELECT NEXTVAL('employee_id_seq');
SELECT CURRVAL('employee_id_seq');
- 序列的重置和重新开始:可以使用
SETVAL
函数来设置序列的当前值,从而实现序列的重置和重新开始。例如:
SELECT SETVAL('employee_id_seq', 1);
- 序列的缓存:可以在创建序列时设置
CACHE
参数来指定序列的缓存大小,以提高性能。缓存大小表示序列一次递增的值的个数,当序列的当前值达到缓存大小时,会再次递增缓存大小个值,减少序列访问的开销。例如:
CREATE SEQUENCE employee_id_seq CACHE 10;