0

Springs のデフォルト リポジトリを使用してオブジェクトを永続化しようとすると、何かが機能しない理由を理解するのに苦労しています。永続化レイヤーと Spring MVC フレームワークとして休止状態を使用しています。休止状態のマッピング ファイルの代わりに JPA を使用します。

私が見ているエラーは次のとおりです。

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_id 列から type.id 列に外部キー制約を適切に設定しています。オブジェクトをすべてコードで適切に表すことができますが、次のリポジトリでオブジェクトを永続化しようとすると、前述のエラーが発生します。

public interface QuestionRepository extends CrudRepository<Question, Long> {
    public List<Question> findByDatasetInstanceId(Long datasetInstanceId);
}

明確にするために。新しい質問オブジェクトを作成し、リポジトリを使用してデータベースからタイプ オブジェクトを取得できます。question.type をこの新しい型オブジェクトに設定できますが、上記のリポジトリを使用してその型を含む質問を永続化しようとすると、そのエラーが発生します。デバッガーで型オブジェクトをチェックアウトしましたが、問題はないようです。手がかりや提案は役に立ちます。ある種のエスケープ文字シーケンスのように見えますが、よくわかりません。

4

1 に答える 1

1

だから私はこれについて本当にばかげていました。適切な注釈がありません。挿入するために型 ID を取得していませんでしたが、何らかの方法でこの Java オブジェクトを挿入しようとしました。

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

上記のコードは問題を解決しました

于 2012-10-19T09:27:37.017 に答える