Estou enfrentando o que considero um problema simples com o Hibernate, mas não consigo resolvê-lo (os fóruns do Hibernate inacessíveis certamente não ajudam).
Eu tenho uma classe simples que gostaria de persistir, mas continuo recebendo:
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 ]
O código relevante para a classe persistida é:
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;
}
}
E o código em execução real é simples:
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();
}
Tentei algumas "estratégias" na GeneratedValue
anotação, mas parece que não funciona. A inicialização id
também não ajuda! (por exemplo Long id = 20L
).
Alguém poderia lançar alguma luz?
EDIT 2: confirmado: mexer com @GeneratedValue(strategy = GenerationType.XXX)
não resolve
RESOLVIDO: recriar o banco de dados resolveu o problema
GenerationType
em @GeneratedValue
partir IDENTITY
para AUTO
e funcionou para mim. Além disso, você pode ter a propriedade de incremento automático definida no MySQL.