ExampleMatcher的matching方法

matching方法是ExampleMatcher类中的一个方法,用于将一个查询对象与一个示例对象进行比较,并根据比较结果生成一个Criteria对象,用于查询数据库。它的定义如下:

Criteria matching(Object example);

其中,example参数是一个示例对象,可以是任何Java对象。matching方法会根据该示例对象的属性值和ExampleMatcher对象中定义的匹配规则,生成一个Criteria对象,用于查询数据库。

下面是一个示例代码:

ExampleMatcher matcher = ExampleMatcher.matching()
    .withMatcher("name", startsWith().ignoreCase())
    .withMatcher("age", greaterThan(18));

User user = new User();
user.setName("John");
user.setAge(25);

Criteria criteria = matcher.matching(user);

在上面的代码中,我们创建了一个ExampleMatcher对象,定义了两个匹配规则:name属性应该以传入的查询参数为开头,不区分大小写,而age属性应该大于18。然后,我们创建了一个示例对象user,并将其应用于ExampleMatcher对象的matching方法中,生成一个Criteria对象criteria,用于查询数据库。

最终生成的Criteria对象会表示一个MongoDB查询,包含了两个条件:name属性以"John"为开头,不区分大小写,age属性大于18。我们可以将该Criteria对象用于MongoDB的查询方法中,例如:

List<User> users = mongoTemplate.find(Query.query(criteria), User.class);

示例:

ExampleMatcher example = ExampleMatcher.matching();
EdcDataAttachmentConfigPo edcDataAttachmentContext = EdcDataAttachmentConfigPo.builder()
        .natureKey(EdcDataAttachmentConfigKeyPo.builder().dataAttachType(natureKey.getDataAttachType())
                .productName(natureKey.getProductName())
                .productRevision(natureKey.getProductRevision())
                .topPlanName(natureKey.getTopPlanName())
                .topPlanRevision(natureKey.getTopPlanRevision())
                .subPlanName(natureKey.getSubPlanName())
                .subPlanRevision(natureKey.getSubPlanRevision())
                .stepName(natureKey.getStepName())
                .stepSeq(natureKey.getStepSeq())
                .edcPlanName(natureKey.getEdcPlanName())
                .edcPlanRevision(natureKey.getEdcPlanRevision())
                .build())
        .build();

Example<EdcDataAttachmentConfigPo> ex = Example.of(edcDataAttachmentContext, example);
dao.findAll(ex)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
引用中的示范代码展示了如何使用ExampleMatcher进行模糊查询。在示范代码中,对姓名字段进行了前后模糊查询,而对学号字段进行了精确查询。 引用提到,在使用ExampleMatcher时,可以根据需要对不同字段使用不同的查询方式。比如,可以对姓名字段实现前后模糊查询,而对学号字段实现精确查询。 根据以上引用内容,可以使用ExampleMatcher来实现模糊查询,具体步骤如下: 1. 创建一个ExampleMatcher对象,并使用matching()方法进行初始化。 2. 使用withMatcher()方法来指定字段的查询方式。例如,对于姓名字段,可以使用contains()方法来实现前后模糊查询。 3. 将ExampleMatcher对象与实体对象一起传入Example.of()方法中,创建一个Example对象。 4. 使用Example对象进行查询操作,可以通过调用相应的查询方法来实现模糊查询。 请根据具体的需求和示范代码中的实现方式,适当修改代码以实现模糊查询。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [ExampleMatcher 针对不同字段实现不同方式查询](https://blog.csdn.net/weixin_43481812/article/details/115615691)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *3* [jpa基于ExampleMatcherExample实现动态筛选,模糊查询,分页,排序,时间范围筛选](https://blog.csdn.net/Years_of_sorrow/article/details/124444759)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值