Ich stehe vor einem meiner Meinung nach einfachen Problem mit Hibernate, kann es aber nicht lösen (Hibernate-Foren, die nicht erreichbar sind, helfen sicherlich nicht).
Ich habe eine einfache Klasse, die ich gerne fortsetzen würde, aber immer wieder bekomme:
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 ]
Der relevante Code für die persistierte Klasse lautet:
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;
}
}
Und der tatsächliche laufende Code ist einfach:
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();
}
Ich habe einige "Strategien" innerhalb der GeneratedValue
Anmerkung ausprobiert, aber es scheint einfach nicht zu funktionieren. Initialisierung id
hilft auch nicht! (zB Long id = 20L
).
Könnte jemand etwas Licht ins Dunkel bringen?
EDIT 2: bestätigt: Durchspielen mit @GeneratedValue(strategy = GenerationType.XXX)
löst es nicht
Gelöst: Die Neuerstellung der Datenbank hat das Problem gelöst
GenerationType
in @GeneratedValue
von IDENTITY
zu AUTO
und es funktionierte für mich. Sie können auch die Eigenschaft für die automatische Inkrementierung in MySQL festlegen.