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

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

        QueryWrapper 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 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)");

你可能感兴趣的:(mysql,java)