栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

使用spring-data-jpa和spring-mvc过滤数据库行

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

使用spring-data-jpa和spring-mvc过滤数据库行

对于初学者,你应该停止使用

@RequestParam
并将所有搜索字段放在一个对象中(也许为此使用Travel对象)。然后,你可以使用2个选项来动态构建查询

  1. 使用
    JpaSpecificationExecutor
    并写一个
    Specification
  2. 使用
    QueryDslPredicateExecutor
    和使用
    QueryDSL
    编写谓词。

使用

JpaSpecificationExecutor

首先添加

JpaSpecificationExecutor
到你的
TravelRepository
这会给你一个
findAll(Specification)
方法,你可以删除自定义finder方法。

public interface TravelRepository extends JpaRepository<Travel, Long>, JpaSpecificationExecutor<Travel> {}

然后,你可以在存储库中创建一个使用的方法,该方法

Specification
基本上可以构建查询。请参阅Spring Data JPA 文档。

你唯一需要做的就是创建一个实现

Specification
并基于可用字段构建查询的类。使用JPA Criteria API链接构建查询。

public class TravelSpecification implements Specification<Travel> {    private final Travel criteria;    public TravelSpecification(Travel criteria) {        this.criteria=criteria;    }    public Predicate toPredicate(Root<T> root, CriteriaQuery<?> query, CriteriaBuilder builder) {        // create query/predicate here.    }}

最后,你需要修改你的控制器以使用新

findAll
方法(我冒昧地将其清理了一下)。

@RequestMapping("/search")  public String search(@ModelAttribute Travel search, Pageable pageable, Model model) {  Specification<Travel> spec = new TravelSpecification(search);    Page<Travel> travels  = travelRep.findAll(spec, pageable);    model.addObject("page", new PageWrapper(travels, "/search"));    return "travels/list";}

使用

QueryDslPredicateExecutor

首先添加

QueryDslPredicateExecutor
到你的
TravelRepository
这会给你一个
findAll(Predicate)
方法,你可以删除自定义finder方法。

public interface TravelRepository extends JpaRepository<Travel, Long>, QueryDslPredicateExecutor<Travel> {}

接下来,你将实现一种服务方法,该服务方法将使用该Travel对象通过QueryDSL构建谓词。

@Service@Transactionalpublic class TravelService {    private final TravelRepository travels;    public TravelService(TravelRepository travels) {        this.travels=travels;    }    public Iterable<Travel> search(Travel criteria) {        Booleanexpression predicate = QTravel.travel...        return travels.findAll(predicate);    }}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/411237.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号