gpt4 book ai didi

java - 如何在postgresql中设置与id不同的自动增量字段

转载 作者:行者123 更新时间:2023-11-29 12:23:45 25 4
gpt4 key购买 nike

我在 postgresql 表中有 id 列和 position 列。我想定位是自动递增的,所以我添加了 position 使用 serial 数据类型:ALTER TABLE tbl ADD COLUMN position serial;

id       name     position
------- ------- -------
1 S4 4
2 S2 2
3 S3 3
4 S1 1

问题是,当我尝试创建新对象时出现以下错误:org.postgresql.util.PSQLException:错误:PSQLException:错误:“位置”列中的空值违反非空

如何设置position列自动递增?

我的普通对象:

public class Stg {

@Id
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "sequenceGenerator")
@SequenceGenerator(name = "sequenceGenerator")
private Long id;

@NotNull
@Size(max = 20)
@Column(name = "name", length = 20, nullable = false)
private String name;

private Integer position;

最佳答案

第一个你需要创建序列:

CREATE SEQUENCE sys_sequence_name START -9223372036854775808 MINVALUE -9223372036854775808 MAXVALUE 9223372036854775807;

然后创建表,但在声明行参数后添加

CREATE TABLE table_name (

id bigserial primary key,
var_with_seq bigint not null default nextval('sys_sequence_name')

nextval('sys_sequence_name') - 这将使用您创建的序列。

关于java - 如何在postgresql中设置与id不同的自动增量字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54343860/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com