【Oracle实验】字段为空的,无法通过排除判断

Oracle相关文档,希望互相学习,共同进步

风123456789~-CSDN博客


1.场景描述

需求:查询不是某个机构的数据。

同事SQL:where substr(bank_code,1,9) not in('014009001');

看SQL似乎没什么问题,分析数据后发现 not in 不能查询出空数据。

2. 模拟测试

(1)创建测试表

sql 复制代码
create table feng_aa
(ban_code varchar2(100),
ban_name varchar2(100)
)

(2)插入测试数据

(3)不带nvl的查询结果:查不出空的-少数据

select T.*,T.ROWID from feng_aa t where substr(ban_code,1,9) not in('014009001');

(4)带nvl的查询结果:可检索空的

select T.*,T.ROWID from feng_aa t where substr(nvl(ban_code,'X'),1,9) not in('014009001');

3.结论

总结:

where 条件中,如果字段有为空的,无法not in 筛选出空的内容。必须带上nvl 转义处理后,再进行查询。


项目管理--相关知识

项目管理-项目绩效域1/2-CSDN博客

项目管理-项目绩效域1/2_八大绩效域和十大管理有什么联系-CSDN博客

项目管理-项目绩效域2/2_绩效域 团不策划-CSDN博客

高项-案例分析万能答案(作业分享)-CSDN博客

项目管理-计算题公式【复习】_项目管理进度计算题公式:乐观-CSDN博客

项目管理-配置管理与变更-CSDN博客

项目管理-项目管理科学基础-CSDN博客

项目管理-高级项目管理-CSDN博客

项目管理-相关知识(组织通用治理、组织通用管理、法律法规与标准规范)-CSDN博客


Oracle其他文档,希望互相学习,共同进步

Oracle-找回误删的表数据(LogMiner 挖掘日志)_oracle日志挖掘恢复数据-CSDN博客

oracle 跟踪文件--审计日志_oracle审计日志-CSDN博客

ORA-12899报错,遇到数据表某字段长度奇怪现象:"Oracle字符型,长度50"但length查却没有50_varchar(50) oracle 超出截断-CSDN博客

EXP-00091: Exporting questionable statistics.解决方案-CSDN博客

Oracle 更换监听端口-CSDN博客

相关推荐
diaya20 分钟前
麒麟V10 x86系统安装mysql
数据库·mysql
LaughingZhu25 分钟前
Product Hunt 每日热榜 | 2026-02-24
大数据·数据库·人工智能·经验分享·搜索引擎
QEasyCloud20221 小时前
WooCommerce 独立站系统集成技术方案
java·前端·数据库
数据知道2 小时前
MongoDB 数组查询专项:`$all`、`$elemMatch` 与精确匹配数组的使用场景
数据库·mongodb
柒.梧.2 小时前
Java位运算详解:原理、用法及实战场景(面试重点)
开发语言·数据库·python
callJJ2 小时前
深入浅出 MVCC —— 从零理解 MySQL 并发控制
数据库·mysql·面试·并发·mvcc
小杜的生信筆記2 小时前
生信技能技巧小知识,Linux多线程压缩/解压工具
linux·数据库·redis
Smoothcloud润云3 小时前
Google DeepMind 学习系列笔记(3):Design And Train Neural Networks
数据库·人工智能·笔记·深度学习·学习·数据分析·googlecloud
银发控、3 小时前
MySQL覆盖索引与索引下推
数据库·mysql·面试
DolphinDB智臾科技3 小时前
DolphinDB 与英方软件达成兼容互认,共筑高效数据新底座
数据库·时序数据库·dolphindb