Использовать при удалении значение null для внешнего ключа.JAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Использовать при удалении значение null для внешнего ключа.

Сообщение Anonymous »

В этом случае answer_id — это внешний ключ в таблице рейтингов, а answer_id — это первичный ключ в таблице ответов. Мне нужно удалить ответы, но "Невозможно удалить или обновить родительскую строку: ограничение внешнего ключа не выполнено. произошла ошибка. Как установить параметр ON DELETE SET NULL для этого внешнего ключа.
@Entity
@Table(name = "ratings")
public class Ratings {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long rating_id;

@Column(nullable = false, unique = false, length = 45)
private Short ratingValue;

@ManyToOne(cascade = fetch = FetchType.LAZY)
@JoinColumn(name = "userId")
private User user;

@ManyToOne(cascade = fetch = FetchType.LAZY)
@JoinColumn(name = "answer_id")
private Answer answer;

@ManyToOne(cascade = fetch = FetchType.LAZY)
@JoinColumn(name = "question_id")
private Question question;
//getters and setters


@Entity
@Table(name = "answers")
public class Answer {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long answer_id;

@Column(nullable = false, unique = false, length = 100)
private String fullAnswer;

/*Many to one mapping question*/
@ManyToOne(cascade = FetchType.LAZY)
@JoinColumn(name = "question_id")
private Question question;

/* Many to One mapping with users*/
@ManyToOne(cascade = FetchType.LAZY)
@JoinColumn(name = "userId")
private User user;
//getters and setters


Подробнее здесь: https://stackoverflow.com/questions/727 ... oreign-key
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»