我正试图将我的项目从hibernate 3.6升级到4.1.6,我想我已经把所有的jar都放在了正确的位置。。。等等,但现在我有一个例外,谷歌搜索没有得到答案。我的代码在Hibernate 3.6上运行良好,我不确定这是我的映射问题还是其他问题。我正在使用JPA方法配置hibernate 4.1和Spring 3.1.2。
Caused by: org.hibernate.MappingException: Could not create DynamicParameterizedType for type: org.hibernate.type.EnumType
at org.hibernate.mapping.SimpleValue.createParameterImpl(SimpleValue.java:398)
at org.hibernate.mapping.SimpleValue.getType(SimpleValue.java:304)
at org.hibernate.mapping.SimpleValue.isValid(SimpleValue.java:294)
at org.hibernate.mapping.Property.isValid(Property.java:238)
at org.hibernate.mapping.PersistentClass.validate(PersistentClass.java:469)
at org.hibernate.mapping.RootClass.validate(RootClass.java:270)
at org.hibernate.cfg.Configuration.validate(Configuration.java:1294)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1738)
at org.hibernate.ejb.EntityManagerFactoryImpl.<init>(EntityManagerFactoryImpl.java:94)
at org.hibernate.ejb.Ejb3Configuration.buildEntityManagerFactory(Ejb3Configuration.java:905)
... 55 more
Caused by: java.lang.ClassNotFoundException: char
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1711)
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1556)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:186)
at org.hibernate.internal.util.ReflectHelper.classForName(ReflectHelper.java:192)
at org.hibernate.mapping.SimpleValue.createParameterImpl(SimpleValue.java:389)
... 64 more
更新:我在捕获异常的hibernate代码中放置了断点,并找到了它不喜欢的映射,如下所示。
@Entity
@Table(name = "company_addresses")
public class CompanyAddress extends TimeStampedPersistableObject
{
public enum AddressType
{
PUBLIC('p'), SHAREHOLDER('s');
private final char typeCode;
AddressType(char typeCode)
{
this.typeCode = typeCode;
}
public static AddressType parse(char c)
{
for (AddressType addressType : AddressType.values())
{
if (addressType.value() == c)
{
return addressType;
}
}
return null;
}
public char value()
{
return typeCode;
}
}
@Column(name = "address_type")
@Enumerated(EnumType.STRING)
private char type;
原来我有一个额外的@Enumerated,hibernate 3.6忽略了它,这与hibernate 4.1 混淆了
@Column(name = "address_type")
@Enumerated(EnumType.STRING)
private char type;
我忘记了@Enumerated在这个字段上,它有一个char类型,但setters和getter使用了一个正确的Enum。删除@Enumerated修复了这个问题,这是我映射中的一个错误。
Hibernate 4.1未能指示表的名称和列的名称,这使得很难弄清楚是哪个映射导致了问题。