Java @Repository@组件注释的NoSuchBeanDefinitionException
我正在从事SpringHibernate项目。如果我没有将bean名称与@Repository或@Component一起提到,我会得到一个错误“NoSuchBeanDefinitionException”。 例如:@Repository(“HibernateDaoImpl”)可以正常工作。 @存储库给出了一个错误Java @Repository@组件注释的NoSuchBeanDefinitionException,java,spring,hibernate,Java,Spring,Hibernate,我正在从事SpringHibernate项目。如果我没有将bean名称与@Repository或@Component一起提到,我会得到一个错误“NoSuchBeanDefinitionException”。 例如:@Repository(“HibernateDaoImpl”)可以正常工作。 @存储库给出了一个错误 INFO: Building new Hibernate SessionFactory Exception in thread "main" org.springframework.b
INFO: Building new Hibernate SessionFactory
Exception in thread "main" org.springframework.beans.factory.NoSuchBeanDefinitionException: No bean named 'HibernateDaoImpl' is defined
at org.springframework.beans.factory.support.DefaultListableBeanFactory.getBeanDefinition(DefaultListableBeanFactory.java:641)
at org.springframework.beans.factory.support.AbstractBeanFactory.getMergedLocalBeanDefinition(AbstractBeanFactory.java:1159)
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:282)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:195)
at org.springframework.context.support.AbstractApplicationContext.getBean(AbstractApplicationContext.java:973)
at com.amal.springdb.JdbcDemo.main(JdbcDemo.java:23)
org.hibernate.dialogue.derbydialogue
Spring默认bean名称基于。因此,请使用context.getBean(“HibernateDoiMPL”)
或根据@Repository(“HibernateDoiMPL”)
指定所需的bean名称,粘贴自动连接存储库类的代码。@AndyDufresne-我已将代码更新到我的帖子中。谢谢您的回复。我用代码更新了我的帖子。我仍然没有看到刚才添加的使用HibernateDaoImpl.的代码。它的JdbcDemo类。就在xml代码上方,这个答案是正确的。如果您没有明确地将存储库命名为@repository(“HibernateDAOImpl”)
,那么Spring将使用类名的小写首字母命名它,如HibernateDAOImpl
@Michal@LucasP非常感谢。我明白了。
package com.amal.springdb.model;
import javax.persistence.Entity;
import javax.persistence.Id;
@Entity
public class Circle {
@Id
private int id;
private String name;
public Circle(int id, String name) {
this.id = id;
this.name = name;
}
public Circle() {
// TODO Auto-generated constructor stub
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
package com.amal.springdb.dao;
import org.hibernate.Query;
import org.hibernate.SessionFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;
@Repository //("HibernateDaoImpl")
public class HibernateDaoImpl {
@Autowired
private SessionFactory sessionFactory;
public int getCircleCount(){
String hql = "select count(*) from Circle";
Query query = getSessionFactory().openSession().createQuery(hql);
int i = ((Long)query.uniqueResult()).intValue();
return i;
}
public SessionFactory getSessionFactory() {
return sessionFactory;
}
public void setSessionFactory(SessionFactory sessionFactory) {
this.sessionFactory = sessionFactory;
}
}
package com.amal.springdb;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.amal.springdb.dao.HibernateDaoImpl;
import com.amal.springdb.dao.JdbcDaoImpl;
import com.amal.springdb.dao.SimpleJdbcDaoImpl;
import com.amal.springdb.model.Circle;
public class JdbcDemo {
public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("spring.xml");
HibernateDaoImpl hibernateDaoImpl = (HibernateDaoImpl) context.getBean("HibernateDaoImpl");
System.out.println(hibernateDaoImpl.getCircleCount());
}
}
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<context:annotation-config></context:annotation-config>
<context:component-scan base-package="com.amal.springdb"></context:component-scan>
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="org.apache.derby.jdbc.ClientDriver"></property>
<property name="url" value="jdbc:derby://localhost:1527/db;create=true"></property>
<property name="initialSize" value="2"></property>
<property name="maxActive" value="5"></property>
</bean>
<bean id="SimpleJdbcDaoImpl" class="com.amal.springdb.dao.SimpleJdbcDaoImpl">
<property name="dataSource" ref="dataSource"></property>
</bean>
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<property name="packagesToScan" value="com.amal.springdb.model"></property>
<property name="hibernateProperties">
<props>
<prop key="dialect">org.hibernate.dialect.DerbyDialect</prop>
</props>
</property>
</bean>
</beans>