• springboot使用MongoTemplate根据正则表达式查询日期数据


     一、日期正则表达式测试

    • 匹配HH:mm:ss正则表达式写法有很多列举两个

    .(点)代表任意匹配

    ^开头必须是跟着的

    : 精确匹配,必须是:

    ([0-1]?[0-9]|2[0-3]).([0-5][0-9]).([0-5][0-9])

    ^([0-1]?[0-9]|2[0-3]).([0-5][0-9]).([0-5][0-9])$
    ([0-1]?[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])

    1. public class RegexDemo {
    2. public static void main(String[] args) {
    3. String str = "2023-10-10 00:00:00";
    4. String regex1 ="^\\d{4}-\\d{2}-\\d{2}.([0-1]?[0-9]|2[0-3]).([0-5][0-9]).([0-5][0-9])$";
    5. Pattern p = Pattern.compile(regex1);
    6. Matcher m = p.matcher(str);
    7. boolean flag = m.matches();
    8. System.out.println("yyyy-MM-dd HH:mm:ss格式正则表达式测试" + flag);
    9. String regex2 ="^\\d{4}-\\d{2}-\\d{2}.\\d{2}:\\d{2}:\\d{2}$";
    10. Pattern p2 = Pattern.compile(regex2);
    11. Matcher m2 = p2.matcher(str);
    12. boolean flag2 = m2.matches();
    13. System.out.println("yyyy-MM-dd HH:mm:ss忽略时分秒" + flag2);
    14. String regex3 ="^2023-10-10 \\d{2}:\\d{2}:\\d{2}$";
    15. Pattern p3 = Pattern.compile(regex3);
    16. Matcher m3 = p3.matcher(str);
    17. boolean flag3 = m3.matches();
    18. System.out.println("yyyy-MM-dd HH:mm:ss忽略时分秒精确匹配" + flag3);
    19. }
    20. }

    二、Mongo正则查询与条件查询对比 

    1. @Resource
    2. private MongoTemplate mongoTemplate;
    3. @Test
    4. public void compareRegexToEquals() {
    5. String str ="^"+"2023-10-07"+".\\d{2}:\\d{2}:\\d{2}$";
    6. Pattern pattern = Pattern.compile(str, Pattern.CASE_INSENSITIVE);
    7. List maps = mongoTemplate.find(new Query(Criteria.where("updateTime").regex(pattern))
    8. .with(Sort.by(
    9. Sort.Order.asc("updateTime")
    10. )),
    11. Map.class, "tbopen_shop_uuid");
    12. System.out.println("正则表达式查询数据=========================" + maps.size() );
    13. maps = maps.stream().limit(5).collect(Collectors.toList());
    14. maps.forEach(System.out::println);
    15. String startTime = "2023-10-07 00:00:00";
    16. String endTime = "2023-10-07 23:59:59";
    17. List shop = mongoTemplate.find(new Query(Criteria.where("updateTime").gte(startTime).lte(endTime))
    18. .with(Sort.by(
    19. Sort.Order.asc("updateTime")
    20. )),
    21. Map.class, "tbopen_shop_uuid");
    22. System.out.println("使用条件查询数据=========================" + shop.size());
    23. shop = maps.stream().limit(5).collect(Collectors.toList());
    24. shop.forEach(System.out::println);
    25. }

    我这里这查询了一天的测试数据,比对结果后发现两种查询结果是一致的,取了前五条数据做对比,

    突然发现正则还是挺牛的!

    之后我们取每天的值进行字符串拼接则可以实现分组统计的需求了.

     

  • 相关阅读:
    链表
    软考是什么?软考的考试安排是什么时候?
    故障诊断 | GADF+Swin-CNN-GAM 的轴承故障诊断模型附matlab代码
    华为OD机考算法题:MVP争夺战
    PyRender离屏渲染快速教程
    matlab使用NCL提供的colormap
    密码学·常用网址
    一个数组去重(filter函数)
    Stable Diffusion 参数介绍及用法
    python+selenium自动化测试项目实战
  • 原文地址:https://blog.csdn.net/m0_74444744/article/details/134447033