Spring Boot org.hibernate.exception.ConstraintViolationException
Posted
技术标签:
【中文标题】Spring Boot org.hibernate.exception.ConstraintViolationException【英文标题】: 【发布时间】:2018-10-20 04:11:21 【问题描述】:当我尝试使用 POST REST API 持久化数据时出现 .ConstraintViolationException。
原因:org.postgresql.util.PSQLException:错误:“id”列中的空值违反非空约束 详细信息:失败行包含(null,John Doe,你好吗?,我很好)。
我正在使用 @GeneratedValue(strategy = GenerationType.IDENTITY) 从 Hibernate 自动生成“id”,我不确定是否缺少 application.properties 中的任何配置。我正在使用 Postgres 数据库。
我尝试使用 GenerationType.AUTO,但我从 postgres 收到 hibernate_sequence missing 错误。
谢谢!
使用 Postman POST REST API 输入
"personName": "John Doe",
"question": "How are you?",
"response": "I am fine"
questionnaries.sql
CREATE TABLE questionnaries(
id BIGINT PRIMARY KEY,
personName VARCHAR(255) NOT NULL,
question VARCHAR(255) NOT NULL,
response VARCHAR(255) NOT NULL
);
Questionnarie.java #
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
import javax.validation.constraints.NotNull;
@Entity
@Table(name = "questionnaries")
public class Questionnarie
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private Long id;
@Column(name = "personname")
@NotNull
private String personname;
@Column(name = "question")
@NotNull
private String question;
@Column(name = "response")
@NotNull
private String response;
public Questionnarie()
public Questionnarie(@NotNull String personname, @NotNull String question, @NotNull String response)
super();
this.personname = personname;
this.question = question;
this.response = response;
public Long getId()
return id;
public void setId(Long id)
this.id = id;
public String getPersonname()
return personname;
public void setPersonname(String personname)
this.personname = personname;
public String getQuestion()
return question;
public void setQuestion(String question)
this.question = question;
public String getResponse()
return response;
public void setResponse(String response)
this.response = response;
application.properties
# ===============================
# = DATA SOURCE
# ===============================
# Set here configurations for the database connection
spring.datasource.jndi-name=java:jboss/datasources/test_data_source
# ===============================
# = JPA / HIBERNATE
# ===============================
# Show or not log for each sql query
spring.jpa.show-sql=true
# Allows Hibernate to generate SQL optimized for a particular DBMS
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.PostgreSQLDialect
【问题讨论】:
【参考方案1】:将您的脚本更改为:
CREATE TABLE questionnaries(
id BIGINT PRIMARY KEY GENERATED BY DEFAULT AS IDENTITY,
personName VARCHAR(255) NOT NULL,
question VARCHAR(255) NOT NULL,
response VARCHAR(255) NOT NULL
);
【讨论】:
正如目前所写,您的答案尚不清楚。请edit 添加其他详细信息,以帮助其他人了解这如何解决所提出的问题。你可以找到更多关于如何写好答案的信息in the help center。 请在您的答案中添加其他信息,以帮助读者了解它为什么/如何解决问题。【参考方案2】:这意味着您的数据库支持主键值的序列。因此,在您的情况下,您必须创建一个数据库序列,然后使用 @GeneratedValue(strategy=GenerationType.AUTO)
或 @GeneratedValue(strategy=GenerationType.SEQUENCE, generator="seq")
@SequenceGenerator(name="seq", sequenceName = "db_seq_name")
为主键字段生成值。
还要确保将 SERIAL 添加到 SQL 中,使其看起来像:id SERIAL PRIMARY KEY
请参阅the serial data types 的 PostgreSQL 文档。
【讨论】:
如果我使用@GeneratedValue(strategy=GenerationType.SEQUENCE, generator="seq") 那么generator="seq" 表示数据库中序列的名称是“seq”?还是以上是关于Spring Boot org.hibernate.exception.ConstraintViolationException的主要内容,如果未能解决你的问题,请参考以下文章
Spring Boot 2.1 缺少多个 org.hibernate.jpa.event 类
在 Spring Boot 中向本机查询添加参数会导致“org.hibernate.exception.SQLGrammarException”,
Spring boot 无法评估表达式方法抛出 'org.hibernate.LazyInitializationException' 异常。使用 getter,ManyToMany 关系