Довольно многое говорит об этом в названии. У меня есть класс, который выглядит примерно так:
@Entity
@Table(name="FOO")
public class Foo {
private String theId;
@Id
@Column(name = "FOO_ID")
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "fooIdSeq")
@SequenceGenerator(name = "fooIdSeq", sequenceName = "SQ_FOO_ID", allocationSize = 10)
public String getTheId() { return theId; }
public String setTheId(String theId) { this.theId = theId; }
}
Используя Oracle 11g, столбец FOO_ID
является VARCHAR2
, но последовательность SQ_FOO_ID
дает a NUMBER
. База данных, по-видимому, довольна этим, но приложение должно иметь возможность поддерживать нечисловые идентификаторы, которые могут быть вставлены в этот столбец вне приложения.
Учитывая приведенный выше код, я получаю a org.hibernate.id.IdentifierGenerationException: Unknown integral data type for ids : java.lang.String
. Есть ли способ сделать это отображение?
Использование Hibernate 3.6.