org.postgresql.util.PSQLException:错误:对于类型字符变化的值太长(255)

Posted

技术标签:

【中文标题】org.postgresql.util.PSQLException:错误:对于类型字符变化的值太长(255)【英文标题】:org.postgresql.util.PSQLException: ERROR: value too long for type character varying(255) 【发布时间】:2016-07-26 13:33:53 【问题描述】:

当我执行我的项目时,我得到这个错误:

目标是使用hibernatejson文本保存到数据库中。

Users.java & UsersBooks.java 同样,

Books.java:

@Entity
@Table(name="tblbooks")
public class Books 


@Id
@Column(name = "bookshareId")
private int bookshareId;

@Column(name="author")
private String author;

@Column(name = "availableToDownload")
private int availableToDownload;

@Column(name = "briefSynopsis")
private String briefSynopsis;

@Column(name="category")
private String category;

@Column(name = "completeSynopsis")
private String completeSynopsis;

@Column(name = "contentId")
private int contentId;

@Column(name = "copyright")
private Date copyright;

@Column(name="downloadFormat")
private String downloadFormat;

@Column(name="dtbookSize")
private int dtbookSize;

@Column(name = "freelyAvailable")
private int freelyAvailable;

@Column(name = "brf")
private int brf;

@Column(name = "daisy")
private int daisy;

@Column(name = "images")
private int images;

@Column(name = "isbn13")
private String isbn13;

@Column(name="language")
private String language;

@Column(name = "publishDate")
private Date publishDate;

@Column(name = "publisher")
private String publisher;

@Column(name = "quality")
private String quality;

@Column(name = "title")
private String title;

@OneToMany(mappedBy="book")
private List<UsersBooks> usersBooks;



//Getters & Setters

【问题讨论】:

进入数据库,你已经设置了字段类型字符,它的长度是 255,这是这里的原因,请或者最大。 255 到 1000(长于 255)或将类型从字符更改为文本或 varchar。 发送到 PostgreSQL 的 SQL 是什么? 【参考方案1】:

您尝试保存长度超过 255 个字符的字符串值。只需增加一列长度

@Column(name = "xxx", length = 1024)

您还需要更改数据库中的列长度。

当你使用

@Column(name = "xxx")

Hibernate 使用默认的列长度。

您可以使用@Lob 处理非常大的文本数据。

请使用xxx_users 代替tblusers

使用User 代替Users

在关联的@OneToMany 部分使用CascadeType.ALL

对关联的@ManyToOne 部分使用延迟加载。

@ManyToOne(fetch = FetchType.Lazy)
pravate User user;

【讨论】:

【参考方案2】:

对于长度超过 255 个字符的字符串,您可以增加列长度:

@Column(length = 2048)
private String column;

对于大尺寸:

@Lob
private String column;

无限大小:

@Column(columnDefinition="text")
private String column;

【讨论】:

【参考方案3】:

错误消息告诉您正在尝试存储一个对于其目标列 (255) 来说太大的字符串。

你可以:

增加列大小或 将列类型更改为TEXT,而不是VARCHAR(255)

【讨论】:

以上是关于org.postgresql.util.PSQLException:错误:对于类型字符变化的值太长(255)的主要内容,如果未能解决你的问题,请参考以下文章