簡體   English   中英

如何發布ArrayList來啟動H2 DB

[英]How to POST ArrayList to spring boot H2 DB

我收到以下錯誤:

{"timestamp":1535929757444,"status":500,"error":"Internal Server Error","exception":"org.springframework.dao.DataIntegrityViolationException","message":"could not execute statement; SQL [n/a]; constraint [\"PRIMARY KEY ON PUBLIC.WT_TASK(TASK_ID)\"; SQL statement:\ninsert into wt_task (exercise_id, task_id) values (?, ?) [23505-196]]; nested exception is org.hibernate.exception.ConstraintViolationException: could not execute statement","path":"/api/word-transformation/new"}

我能夠創建一個從數據庫中獲取JSON的服務,但是我無法設法上傳它們。

這是我的服務:

public WordTransformationExercise save(WordTransformationExerciseRequest wtRequest) {
    WordTransformationExercise wordTransformation = new WordTransformationExercise();
    wordTransformation.setAuthorId(wtRequest.getAuthor_id());

    List<WordTransformationTaskRequest> testP = wtRequest.getwt_task();

    List<WordTransformation> thisIsIt = new ArrayList<WordTransformation>();
    for(WordTransformationTaskRequest task : testP) {
          WordTransformation send = new WordTransformation();
          send.setBody(task.getBody());
          send.setResult(task.getResult());
          send.setWord(task.getWord());
          send.setWordAtIndex(task.getWord_at_index());
          thisIsIt.add(send);
    }
    wordTransformation.setwt_task(thisIsIt);

    this.wtRepository.save(wordTransformation);

    return wordTransformation;
  }

這是我的實體:

    @Entity
@Table(name = "wt_exercise")
public class WordTransformationExercise implements Serializable {
      @Id
      @Column(name = "id")
      @GeneratedValue(strategy = GenerationType.IDENTITY)
      private Long id;

      @Column(name = "author_id")
      private Long authorId;

      @ManyToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
      @JoinTable(name = "wt_task",
              joinColumns = @JoinColumn(name = "exercise_id", referencedColumnName = "id"),
              inverseJoinColumns = @JoinColumn(name = "task_id", referencedColumnName = "task_id"))
      private List<WordTransformation> wt_task;

      public Long getId() {
            return id;
          }

      public void setId(Long id) {
            this.id = id;
          }

      public Long getAuthorId() {
            return authorId;
          }

      public void setAuthorId(Long authorId) {
            this.authorId = authorId;
          }

      public void setwt_task(List<WordTransformation> list) {
          this.wt_task = list;
          }

          public Collection<?> getwt_task() {
            return this.wt_task;
          }
}

這是任務實體:

    @Entity
@Table(name = "wt_task")
public class WordTransformation implements Serializable {

    @Id
    @Column(name = "task_id")
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long task_id;

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

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

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

    @Column(name = "word_at_index")
    private Integer wordAtIndex;

    @Column(name = "exercise_id")
    private Long exercise_id;

    public void setExercise_id(Long exercise_id) {
        this.exercise_id = exercise_id;
    }

    public Long getExercise_id() {
        return exercise_id;
    }

    public void setId(Long task_id) {
        this.task_id = task_id;
    }

    public Long getId() {
        return task_id;
    }

    public void setBody(String body) {
        this.body = body;
    }

    public String getBody() {
        return body;
    }

    public void setResult(String result) {
        this.result = result;
    }

    public String getResult() {
        return result;
    }

    public void setWord(String word) {
        this.word = word;
    }

    public String getWord() {
        return word;
    }

    public void setWordAtIndex(Integer wordAtIndex) {
        this.wordAtIndex = wordAtIndex;
    }

    public Integer getWordAtIndex() {
        return wordAtIndex;
    }
}

將wt_task設置為null時,我的API返回“ id”和“ authorId”很好

這是我的sql的示例:

將wt_exercise(id,author_id)值插入(2,2);

INSERT INTO wt_task(body,result,word,word_at_index,exercise_id,task_id)VALUES('please start','running','run',13,2,2);

這取決於您要執行的操作。

如果嘗試更新現有實體,則應從存儲庫中檢索它並設置值,而不是創建新對象並嘗試使用現有鍵保存它。

如果您嘗試創建新的東西,那么根本不要設置密鑰。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM