select create_date FROM unlimited_user_history WHERE 1 != 1;
筛选结果为0件
但是用了聚合函数
select MAX(create_date) FROM unlimited_user_history WHERE 1 != 1;
即使where条件不满足,结果还是有1件;
这个很正常,第一个之所以返回0条,是因为1!=1 是不成立的,所以就没有结果集了。
而第2个,也是一样,where过滤1!=1也是没有数据,但是聚合函数就算在1条记录也没有的情况下,也会返回1一个值,那就是null
SQL中关于where后面不能放聚合函数(如sum等)的解决办法
我们在编写较为复杂的SQL语句的时候,常常会遇到需要将sum()放到where后面作为条件查询,事实证明这样是无法执行的,执行会报【此处不允许使用分组函数】异常。 那么如何解决呢,使用HAVING关键字 示例: select sum(amount) from table group by clientId having sum(amount) >100
在第一节基础上 更新了函数和执行顺序:实操了字符数函数、时间函数、字段截取函数、interval函数等,除最后顺序实操因未导入数据库,导致无法执行