Spring Data JPA框架的核心概念与Repository接口详解

网友投稿 311 2022-08-01


目录1 核心概念CrudRepository接口PagingAndSortingRepository接口2 查询方法3 后续内容介绍

1 核心概念

Spring Data存储库抽象的中心接口是Repository。它把要管理的实体类以及实体类的ID类型作为类型参数。这个接口主要是作为一个标记接口,用来捕捉工作中的类型,并帮助你发现扩展这个接口的接口。CrudRepository接口为被管理的实体类提供复杂的CRUD功能。

自己可以看看Repository的扩展接口以及实现类 IDEA中将光标定位在Repository.java文件中, ctrl+h快捷键就可以看。

类图继承关系如下:

CrudRepository接口

这个接口定义了一套CRUD基本操作的方法,使用起来很方便

CrudRepository接口比较强大的地方在于可以派生方法,什么意思, 举个例子

you一张用户表,如果你想按照某个字段统计一下数量, 这个实现的确非常强大。

public interface MemberMapper extends CustomRepository {

/** 派生方法按照用户名统计人数 */

Long countByMemberName(String username);

/** 派生方法按照用户部门号统计人数 */

Long countByDeptId(Integer deptId);

}

PagingAndSortingRepository接口

在CrudRepository之上,有一个PagingAndSortingRepository的抽象,它增加了额外的方法以方便对实体类的分页查询访问

2 查询方法

标准的CRUD功能库通常有对底层数据存储的查询。使用Spring Data,声明这些查询需要4个步骤:

1】声明一个扩展Repository或其子接口之一的接口,并指定它应该处理的实体类和ID类型

interface MemberRepository extends Repository { … }

2】在接口中声明查询方法

interface MemberRepository extends Repository {

List findByMembername(String username);

}

3】设置Spring为这些接口创建代理实例, 可以使用配置类或xml配置文件的方式来实现

通过 配置类的方式,示例如下:

import org.springframework.data.jpa.repository.config.EnableJpaRepositories;

@EnableJpaRepositories

public class MyConfig {

}

通过 xml配置文件的方式,示例如下:

xmlns:xsi="http://w3.org/2001/XMLSchema-instance"

xmlns:jpa="http://springframework.org/schema/data/jpa"

xsi:schemaLocation="http://springframework.org/schema/beans

https://springframework.org/schema/beans/spring-beans.xsd

http://springframework.org/schema/data/jpa

https://springframework.org/schema/data/jpa/spring-jpa.xsd">

xmlns:xsi="http://w3.org/2001/XMLSchema-instance"

xmlns:jpa="http://springframework.org/schema/data/jpa"

xsi:schemaLocation="http://springframework.org/schema/beans

https://springframework.org/schema/beans/spring-beans.xsd

http://springframework.org/schema/data/jpa

https://springframework.org/schema/data/jpa/spring-jpa.xsd">

本示例中使用的是JPA命名空间。如果你对任何其他存储使用存储库抽象,你需要将其修改成你的存储模块的对应命名空间声明。换句话说,你应该把jpa换成其他的存储类型,例如mongodb。

另外,请注意,JavaConfig配置类并不明确地配置扫描的基础包,因为默认情况下会使用注释类的包。要自定义要扫描的包,请使用数据存储特定库的 @Enable${store}Repositories-annotation 的 basePackage… 属性之一。什么意思呢,举例:

如果你的store类型是 mongodb, 就使用@EnableMongoRepositories

@Configuration

@EnableMongoRepositories(*arrayOf("com.kkarma.repository", "com.???.???"))

class PersistenceConfig : AbstractMongoConfiguration() {

}

如果你的store类型是 redis, 就使用@EnableRedisRepositories

如果你的store类型是 jpa, 就使用@EnableJpaRepositories

简单配置单个package,格式如下:

@EnableJpaRepositories("com.spr.repository")

简单配置支持多个package,格式如下:

@EnableJpaRepositories({"com.cshtong.sample.repository", "com.cshtong.tower.repository"})

4】注入Repository实例并使用它

@Service

public class MemberServiceImpl implements MemberService {

private final MemberMapper memberMapper;

public MemberServiceImpl(MemberMapper memberMapper) {

this.memberMapper = memberMapper;

}

@Override

public ApiResponse insertMember(Member member) {

Member user = memberMapper.save(member);

return ApiResponse.success("新增成功", user);

}

}

3 后续内容介绍

我们详细解释上面四步操作中的详细内容。

定义repository接口定义查询方法创建Repository实例为Spring Data Repository库定制实现


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Spring Data JPA实现持久化存储数据到数据库的示例代码
下一篇:SpringMVC+Shiro的基本使用及功能介绍(spring整合shiro原理)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~