MySQL 中有关 NULL

java 复制代码
@Entity
@Data
public class User {
    @Id
    @GeneratedValue(strategy = IDENTITY)
    private Long id;
    private Long score;
}
    @Autowired
    private UserRepository userRepository;
    @PostConstruct
    public void init() {
        userRepository.save(new User());
    }
@Repository
public interface UserRepository extends JpaRepository<User, Long> {
    @Query(nativeQuery=true,value = "SELECT SUM(score) FROM `user`")
    Long wrong1();
    @Query(nativeQuery = true, value = "SELECT COUNT(score) FROM `user`")
    Long wrong2();
    @Query(nativeQuery = true, value = "SELECT * FROM `user` WHERE score=null")
    List<User> wrong3();
}

显然,这三条 SQL 语句的执行结果和我们的期望不同:虽然记录的 score 都是 NULL,但 sum 的结果应该是 0 才对;虽然这条记录的 score 是 NULL,但记录 总数应该是 1 才对;使用 =NULL 并没有查询到 id=1 的记录,查询条件失效。

原因是:MySQL 中 sum 函数没统计到任何记录时,会返回 null 而不是 0,可以使用 IFNULL 函数把 null 转换为 0;MySQL 中 count 字段不统计 null 值, COUNT(*) 才是统计所有记录数量的正确方式。MySQL 中使用诸如 =、、> 这样的算数比较操作符比较 NULL 的结果总是 NULL,这种比较就显得没有任何意 义,需要使用 IS NULL、IS NOT NULL 或 ISNULL() 函数来比较。

java 复制代码
@Query(nativeQuery = true, value = "SELECT IFNULL(SUM(score),0) FROM `user`")
Long right1();
@Query(nativeQuery = true, value = "SELECT COUNT(*) FROM `user`")
Long right2();
@Query(nativeQuery = true, value = "SELECT * FROM `user` WHERE score IS NULL")
List<User> right3();
相关推荐
代码雕刻家22 分钟前
MySQL和SQL Server注意事项
数据库·mysql
代码探秘者23 分钟前
【Redis】分布式锁深度解析:实现、可重入、主从一致性与强一致方案
java·数据库·redis·分布式·缓存·面试
IvorySQL24 分钟前
IvorySQL 5.3 正式发布:基于 PG 18.3 内核,多特性升级+全场景适配
数据库·postgresql·开源
冰糖拌面27 分钟前
mysql 与 pg 的网卡监听参数
数据库·mysql·postgresql
DBA小马哥38 分钟前
智能电网调度系统国产化:为什么总卡在数据库替换这一步?
数据库
JAVA学习通1 小时前
InnoDB 存储引擎
java·数据库·mysql
Keanu-1 小时前
Mysqlrouter 配置与测试
mysql·adb
oradh1 小时前
Oracle 11g单库环境PSU补丁安装
数据库·oracle
Java面试题总结1 小时前
PostgreSQL表名超长踩坑记
数据库·postgresql
泯仲2 小时前
从零起步学习MySQL 第三章:DML语句定义及常见用法示例
数据库·学习·mysql