1
我該如何解決這個異常? 例外:spring和hibernate集成註解導致PojoEntityTuplizer
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in class path resource [com/home/app/database/Hibernate-ctx.xml]:
Invocation of init method failed; nested exception is org.hibernate.HibernateException: Unable to instantiate default tuplizer [org.hibernate.tuple.entity.PojoEntityTuplizer]
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1420)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:519)
at org.spr......
Caused by: org.hibernate.HibernateException: Unable to instantiate default tuplizer [org.hibernate.tuple.entity.PojoEntityTuplizer]
at org.hibernate.tuple.entity.EntityTuplizerFactory.constructTuplizer(EntityTuplizerFactory.java:108)
at org.hibernate.tuple.entity.EntityTuplizerFactory.constructDefaultTuplizer(EntityTuplizerFactory.java:133)
模型類:
@Entity
@Table(name = "LOGIN")
public class UserLogin extends Home implements Serializable {
private static final long serialVersionUID = 1L;
private Integer loginID;
private String loginName;
private String loginPassword;
public UserLogin() {
}
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "LOGIN_ID")
public Integer getLoginID() {
return this.loginID;
}
@Column(name = "LOGIN_NAME")
public String getLoginName() {
return loginName;
}
@Column(name = "LOGIN_PASSWORD")
public String getLoginPassword() {
return loginPassword;
}
和它的對應的設置方法。
Spring上下文文件:
<context:annotation-config />
<context:component-scan base-package="com.home.app" />
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource" />
</property>
...
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="${jdbc.driverClassName}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
</bean>
查詢在MySQL:
CREATE TABLE LOGIN
(
LOGIN_NAME varchar(255),
LOGIN_PASSWORD varchar(255),
LOGIN_ID int(11) not null
);
DAO類:
public class LoginDetailsDAOImpl implements LoginDetailsDAO {
HibernateTemplate hibernateTemplate;
public void setSessionFactory(SessionFactory sessionFactory) {
this.hibernateTemplate = new HibernateTemplate(sessionFactory);
}
@Transactional(readOnly = true)
public List<UserLogin> loginDetails(UserLogin login) {
return hibernateTemplate.find("from Login");
}
}