Spring Data Jpa
什么是Spring Data JPA?
Spring Data 是Spring提供的操作数据的框架在Spring data JPA是Spring data的一个模块,通过Spring data 基于jpa标准操作数据的模块。
Spring Data的核心能力,就是基于JPA操作数据,并且可以简化操作持久层的代码。
Spring Data JPA提供的核心接口
Repository:
@org.springframework.stereotype.Repository public interface UserRepository extends Repository<User, Integer> { }
- 提供了方法名查询方式:
方法的名称要遵循 findBy + 属性名(首字母大写) + 查询条件(首字母大写 Is Equals)
findByNameLike(String name)
findByName(String name)
findByNameAndAge(String name, Integer age)
findByNameOrAddress(String name) 等...
- 基于@Query注解的查询和更新
/** * SQL nativeQuery的值是true 执行的时候不用再转化 * @param name * @return */ @Query(value = "SELECT * FROM table_user WHERE name = ?1", nativeQuery = true) List<User> findByUsernameSQL(String name);
/** * 基于HQL * @param name * @param id * @return */ @Query("Update User set name = ?1 WHERE id = ?2") @Modifying int updateNameAndId(String name, Integer id);
CrudReposiroty : 继承了Repository
CrudRepository
Crud主要是添加了对数据的增删改查的方法
PagingAndSortingRepository: 继承了CrudRepository
PagingAndSortingRepository
/** * 继承了Repository,缺点只能对所有的数据进行排序或者分页 */ @Repository public interface UserPagingAndSortingReposiroty extends PagingAndSortingRepository<User, Integer> { }
UserPagingAndSortingReposirotyTest
JPARepository: 继承了PagingAndSortingRepository接口(提供增删改查)
在开发中常用JPARepository
优点: 对继承父接口中方法的返回值进行了适配,因为在父类接口中通常都返回迭代器,需要我们自己进行强制类型转化。而在JpaRepository中,直接返回了List
JpaRepository
JpaSpecificationExecutor: 这个接口单独存在,没有继承以上说的接口
主要提供了多条件查询的支持,并且可以在查询中添加分页和排序。
因为这个接口单独存在,因此需要配合以上说的接口使用,如:
/** * JpaSpecificationExecutor是单独存在的,需要配合这JpaRepository一起使用 */ @Repository public interface UserJpaSpecificationExecutor extends JpaSpecificationExecutor<User>, JpaRepository<User, Integer> { }
View Code
总结:
Spring Data Jpa中一共提供了
- Repository:
- 提供了findBy + 属性方法
- @Query
- HQL: nativeQuery 默认false
- SQL: nativeQuery 默认true
- 更新的时候,需要配合@Modifying使用
- CurdRepository:
- 继承了Repository 主要提供了对数据的增删改查
- PagingAndSortRepository:
- 继承了CrudRepository 提供了对数据的分页和排序,缺点是只能对所有的数据进行分页或者排序,不能做条件判断
- 开发中经常使用的接口,主要继承了PagingAndSortRepository,对返回值类型做了适配
- JpaSpecificationExecutor
- 提供多条件查询
代码1:UserDao.java
package cn.temptation.dao;
import cn.temptation.domain.Score;
import cn.temptation.domain.User;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
import org.springframework.data.jpa.repository.Query;
public interface UserDao extends JpaRepository<User, Integer>, JpaSpecificationExecutor<User> {
@Query(value = "SELECT * FROM t_user WHERE username = ?1", nativeQuery = true)
User findByUserName(String username);
}
代码2:SaleDao.java
package cn.temptation.dao;
import cn.temptation.domain.Sales;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
public interface SalesDao extends JpaRepository<Sales, Integer>, JpaSpecificationExecutor<Sales> {
}