【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博客

相关推荐
程序猿小D21 分钟前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+jsp实现的个人财务管理系统,推荐!
java·数据库·mysql·spring·毕业论文·ssm框架·个人财务管理系统
钢铁男儿1 小时前
C# 接口(什么是接口)
java·数据库·c#
__风__2 小时前
PostgreSQL kv(jsonb)存储
数据库·postgresql
Databend2 小时前
Databend 产品月报(2025年6月)
数据库
Little-Hu3 小时前
QML TextEdit组件
java·服务器·数据库
保持学习ing5 小时前
day1--项目搭建and内容管理模块
java·数据库·后端·docker·虚拟机
发仔1236 小时前
Oracle与MySQL核心差异对比
mysql·oracle
宇钶宇夕6 小时前
EPLAN 电气制图:建立自己的部件库,添加部件-加SQL Server安装教程(三)上
运维·服务器·数据库·程序人生·自动化
爱可生开源社区6 小时前
SQLShift 重磅更新:支持 SQL Server 存储过程转换至 GaussDB!
数据库
贾修行6 小时前
SQL Server 空间函数从入门到精通:原理、实战与多数据库性能对比
数据库·sqlserver