碰到一个需求是统计每日的数据量,数据库里只存了一个创建时间,具体到分钟的。刚开始写了一版代码:
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)");