Spring Data JPA使用JpaRepository自动装配报No qualifying bean of type错误

在使用Spring Data JPA时,通过继承JpaRepository接口进行数据库操作。但遇到No qualifying bean of type错误。问题在于缺少对repository包的扫描配置,添加相应配置后,自动装配恢复正常,能使用find、delete、save等方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天遇到一个问题折腾蛮久的,在这里记录一下。
毕竟是才刚开始使用Jpa这个技术,总是会遇到各种配置问题。
使用Spring Data Jpa非常的方便,一些简单的操作基本上都不用写具体的实现,
直接写一个接口继承JpaRepository就行了,注意需要带有一个泛型。k = 表映射的实体类,value = 表的Id类型。

public interface UserRepository extends JpaRepository<User, Integer> {}

在使用的时候直接自动装配就好。

@Autowired
private UserRepository repository;

或者为了测试方便,通过构造传参,然后自动装配也行。

private UserRepository repository;

@Autowired
public UserController(UserRepository repository) {
    this.repository = repository;
}

然后就可以使用一些常用的数据库操作,如:findxxx、delete、save。
不过默认没有update方法,如果需要的话,就要在接口中再添加。

好了,说下我遇到的那个问题:

Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [com.example.rest.repository.UserRepository] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {}

写个Demo自动装配的时候,测试报这个错误。
检查一下spring配置文件,才发现少了声明repository所在包位置。

<!-- 表示JPA Repository所在的包 -->
<jpa:repositories base-package="com.example.rest.repository"/>

添加以上配置即可。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值