mysql -sql语句not in判断条件注意事项

sql语句not in判断条件注意事项

  问题描述:mysql数据库,存在两个表org表和kdorg表,用于存储组织信息。现在我需要从org表找出组织,条件为该组织不在kdorg表里。

  sql语句:select o.orgno o.orgname from org o where orgno not in(select kd.orgno from kdorg kd);

  明明org表里存在一些组织,该组织的组织编号不存在于kdorg表,但查询结果就是0条记录。搞了一天,也没搞出问题在哪,头都大了,就是一条简单的sql语句,条件满足,为何就是不对呢?

  原因分析:是因为kdorg表存在一条记录,该记录的orgno为null,导致查询结果为空。把orgno为null的记录从kdorg表删除,该sql语句就能成功查询出所需信息。

  总结: not in /in(不能存在null的字段,否则会导致条件失效,sql语句查不出所需数据)

  改进:(1)select o.orgno o.orgname from org o where orgno not in(select kd.orgno from kdorg kd where kd.orgno is not null);

  (2)保证子查询结果中不存在null。

 

转:https://www.cnblogs.com/chendezhen/p/13890725.html

posted @   rmticocean  阅读(152)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
点击右上角即可分享
微信分享提示