Я зіткнувся з тим, що, на мою думку, є проблемою зі сплячкою, але не можу її вирішити (недосяжні форуми, безумовно, не допомагають).
У мене простий клас, який я хотів би наполегливо, але продовжуйте отримувати:
SEVERE: Field 'id' doesn't have a default value
Exception in thread "main" org.hibernate.exception.GenericJDBCException: could not insert: [hibtest.model.Mensagem]
at org.hibernate.exception.SQLStateConverter.handledNonSpecificException(SQLStateConverter.java:103)
at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:91)
[ a bunch more ]
Caused by: java.sql.SQLException: Field 'id' doesn't have a default value
[ a bunch more ]
Відповідним кодом для збереженого класу є:
package hibtest.model;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Inheritance;
import javax.persistence.InheritanceType;
@Entity
@Inheritance(strategy = InheritanceType.JOINED)
public class Mensagem {
protected Long id;
protected Mensagem() { }
@Id
@GeneratedValue
public Long getId() {
return id;
}
public Mensagem setId(Long id) {
this.id = id;
return this;
}
}
А власне запущений код просто:
SessionFactory factory = new AnnotationConfiguration()
.configure()
.buildSessionFactory();
{
Session session = factory.openSession();
Transaction tx = session.beginTransaction();
Mensagem msg = new Mensagem("YARR!");
session.save(msg);
tx.commit();
session.close();
}
Я спробував деякі "стратегії" в GeneratedValue
примітці, але це, здається, не працює. Ініціалізація теж id
не допомагає! (наприклад Long id = 20L
).
Хтось міг пролити світло?
EDIT 2: підтверджено: возитися з цим @GeneratedValue(strategy = GenerationType.XXX)
не вирішує
ВИРІШЕНО: відтворення бази даних вирішило проблему
GenerationType
в @GeneratedValue
с IDENTITY
к AUTO
і він працював на мене. Також у MySQL можна встановити властивість автоматичного збільшення.