mybatis-plus无法解析Date()问题

碰到一个需求是统计每日的数据量,数据库里只存了一个创建时间,具体到分钟的。刚开始写了一版代码:

        QueryWrapper<Threat> queryWrapper = new QueryWrapper<>()
        // DATE(find_time) 无法解析,返回为null
        queryWrapper.select("DATE(find_time)  date" , "count(*) count");
        queryWrapper.groupBy("DATE(find_time)");
        queryWrapper.orderByDesc("DATE(find_time)");

发现返回直接就为null, 很奇怪,把控制台输出的sql,拿到mysql中执行,发现是没有问题的。慢慢debug发现是`这行的问题, date()方法无法解析。

  queryWrapper.select("DATE(find_time)  date" , "count(*) count");

解决方法: 将date()方法换成了

date_format(threat.find_time,'%Y-%m-%d')

具体代码:

        QueryWrapper<Threat> queryWrapper = new QueryWrapper<>();
        queryWrapper.select("date_format(threat.find_time,'%Y-%m-%d') date" , "count(*) count");
        queryWrapper.groupBy("DATE(find_time)");
        queryWrapper.orderByDesc("DATE(find_time)");
上一篇:Mybatis plus条件构造器QueryWrapper的简单用法


下一篇:[Mybatis-Plus] QueryWrapper中 AND 和OR条件运算逻辑