org.hibernate.id.IdentifierGenerationException: идентификаторы для этого класса должны быть назначены вручную перед вызовом save (): com.app.entites.LDetails - PullRequest
0 голосов
/ 11 февраля 2019

Я много раз пытался вставить значение id в мою таблицу, используя приведенный ниже код, но он всегда выдавал org.hibernate.id.IdentifierGenerationException: идентификаторы для этого класса должны быть назначены вручную перед вызовом save (): com.app.entites.LDetails

Ниже приведен код в классе сущности

@Column(name="LID")
@GenericGenerator(name="generatedId", strategy="com.app.common.IdGenerator")
@GeneratedValue(generator="generatedId", strategy=GenerationType.SEQUENCE)
@NotNull
private String lId;

. Я реализовал генератор идентификаторов, используя IdentifierGenerator, как показано ниже

public class IdGenerator implements IdentifierGenerator{

private static String id;

@Override
public Serializable generate(SharedSessionContractImplementor session, Object object) throws HibernateException {
    Connection con = session.connection();
    try {
        Statement statement = con.createStatement();
        ResultSet rs = statement.executeQuery("select count(ID) from L_DETAILS");
        if(rs.next()) {
            int i = rs.getInt(1)+1;
            this.id="ll"+i;
            System.out.println("generated id is "+id);
            return "l"+i;
        }
    }catch(SQLException e) {
        e.printStackTrace();
    }
    return null;
}

}

Ответы [ 2 ]

0 голосов
/ 11 февраля 2019

Вы забыли добавить аннотацию @Id сверху.Тот факт, что вы добавили аннотацию @GeneratedValue, не означает, что вы можете сэкономить аннотацию @Id.Вам все еще нужно это.

0 голосов
/ 11 февраля 2019

Используйте следующий подход для автоматической генерации первичного ключа в вашем классе сущностей с помощью автоматической идентификации: -

 import javax.persistence.GenerationType;
 import javax.persistence.Id;
 import javax.persistence.Entity;

        @Entity
        @Table(name = "your_table_name")
        public class YourEntityClass{

            @Id
            @GeneratedValue(strategy = GenerationType.AUTO)
            @Column(name = "id")
            private long id;

            //other column names

           // setter & getter methods

        }

После этого при каждом сохранении новой записи в таблице вам не нужносоздать новый идентификатор

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...