Java SQL错误:1366不正确的整数值Spring MVC Hibernate

Java SQL错误:1366不正确的整数值Spring MVC Hibernate,java,spring,hibernate,jpa,spring-mvc,Java,Spring,Hibernate,Jpa,Spring Mvc,在试图使用Springs默认存储库持久化对象时,我很难弄清楚为什么有些东西不起作用。我使用hibernate作为持久层和SpringMVC框架。我使用JPA而不是hibernate映射文件 我看到的错误如下: WARN : org.hibernate.util.JDBCExceptionReporter - SQL Error: 1366, SQLState: HY000 ERROR: org.hibernate.util.JDBCExceptionReporter - Incorrect in

在试图使用Springs默认存储库持久化对象时,我很难弄清楚为什么有些东西不起作用。我使用hibernate作为持久层和SpringMVC框架。我使用JPA而不是hibernate映射文件

我看到的错误如下:

WARN : org.hibernate.util.JDBCExceptionReporter - SQL Error: 1366, SQLState: HY000
ERROR: org.hibernate.util.JDBCExceptionReporter - Incorrect integer value: '\xAC\xED\x00\x05sr\x00!com.kwhours.butternut.domain.Type\xCF;\xBF\xEF\x8A\x82\x87\xF1\x02\x00\x0DZ\x00\x06isLeafI\x00\x05levelL\' for column 'type_id' at row 1
我正在尝试使用JPA注释持久化域对象,该代码的相关部分是:

@Entity
@Table(name = "question")
public class Question implements java.io.Serializable {
    private Type type;

    @Column(name = "type_id")
    public Type getType() {
        return this.type;
    }

    public void setType(Type type) {
        this.type = type;
    }
}
我在question.type\u id列到type.id列上正确设置了外键约束。我能够在代码中正确地表示我的对象,但是当我试图使下面的存储库持久化对象时,我得到了上述错误

public interface QuestionRepository extends CrudRepository<Question, Long> {
    public List<Question> findByDatasetInstanceId(Long datasetInstanceId);
}
public interface QuestionRepository扩展了crudepository{
公共列表findByDatasetInstanceId(长datasetInstanceId);
}

我想说清楚。我可以创建一个新的问题对象,并使用存储库从数据库中检索类型对象。我可以将questions.type设置为这个新类型对象,但每当我试图使用上面的存储库持久化包含该类型的问题时,就会出现该错误。我在调试器中签出了类型对象,它似乎没有任何问题。任何线索或建议都是有用的。这看起来像是某种转义字符序列,但我不是很确定。

所以我真的很傻。我缺少正确的注释,它没有将类型id取出进行插入,而是尝试以某种方式插入这个java对象

@ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "type_id")
public Type getType() {
    return this.type;
}

上面的代码解决了这个问题

它试图插入类型对象的id,该对象是一个Java Long,在数据库中是一个Bigint(20)。这里没有编码错误的字符串,该id是由于数据库自动增量而创建的,因此我怀疑mysql创建id的编码是它无法读取的:)。请同时向您发布
Type
class。这就是我的想法。我认为如果适当地拒绝
类型
实体,它也会起作用。这就是为什么我想看;-)