Spring Data Jpa 中使用CriteriaBuilder动态拼接SQL

之前在我的博客园Spring data jpa - 随笔分类 - 敲代码的小松鼠 - 博客园 (cnblogs.com)有记录过相关技巧问题,之前的应用场景太简单,重新记录一篇。

应用场景

  在Spring Data Jpa中,可以使用提供的Spring Data JPA - query-methods进行方便的查询,甚至可以使用@Query注解自己写HQL或SQL完成更复杂的数据库操作。但是这些都很难实现动态拼接SQL(即where条件中某个参数没有值就不添加这个条件)。


ycyin大约 4 分钟Spring Data JpaSpring Data JpaSpring Boot
Spring Data Jpa 返回自定义对象(实体部分属性、多表联查)

应用场景

  在Spring data jpa中,一般都是直接返回一个实体或者List<实体>或者Page<实体>,这里的实体一般就是与数据库对应的实体类,就像下面这样:

@Repository
public interface IUserDao extends JpaRepository<User, String>, JpaSpecificationExecutor<User>,
        PagingAndSortingRepository<User, String>, Serializable {
    @Override
    Page<User> findAll(Pageable pageable);
    @Override
    List<User> findAll();
    @Override
    User save(User u);
}    

ycyin大约 4 分钟Spring Data JpaSpring Data JpaSpring Boot