oracle 让人抓狂的错误之 null值 与 无值(无结果)-开发系列(一)
近期。在做开发、写存过的时候碰到一些问题,找了好长时间才发现原因。并且是曾经不知道的。
所以在这给记下来 给自己备忘和大家參考。
一 、null值
以下举个最简单的样例。寻常工作其中肯定比这个sql复杂的多,在这仅仅是把这个易错点呈现出来,他可能是一个复杂sql出错的小的 不easy被发现的一个问题。
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveGlhb2hhaTc5OA==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center">
上面是一个非常easy表的全部数据。area_num 区域编码 area_name 区域名称 delflag 有无效标识 1有效 0无效(当中淮北 和宣城的delflag为null)。
如今想找出有效的那些区域信息,所以用以下的语句:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveGlhb2hhaTc5OA==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center">
上面的结果中没有淮北和宣城 跟预想中的不一样 一開始以为是 delflag不为0的全部应该都被查询出来 包含淮北和宣城。
其实 淮北和宣城 delflag的字段是 null值。在oracle里面null值得概念:
NULL是数据库中特有的数据类型,当一条记录的某个列为NULL,则表示这个列的值是未知的、是不确定的。
既然是未知的,就有无数种的可能性。因此。NULL并非一个确定的值。
所以null值(不确定的值) 并不符合 !='0' 这个 条件。相同以下语句也是这样。
二、无结果
无结果事实上就是一个select查询没有结果集(不是null,而是没有结果)
结果为null:
无结果:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveGlhb2hhaTc5OA==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center">
表面看非常的清楚明确,可是到了实际应用中可能 会easy搞错。
以下是演示样例的存储过程:
create or replace function getProceessidAllDealBySkf_l(proceessid in number)
return varchar2 as
cursor pcursor is(
select distinct t.orgid, t.oper_name
from tssa_his_dsg.wh_common_busilog_td t
where t.processinstid = proceessid);--取操作日志表某个工单流程proceessid的操作人所属机构id。和操作名称
orgidCursor pcursor%rowtype;--定义类型为pcursor行数据的 变量
orgid_var varchar2(20);--存放操作人机构id变量
returnflag varchar2(20);--返回的标志位
orgseqflag varchar2(50);--操作人机构id及其全部父id 串起来字符
skforgflag varchar2(20);--存放操作人机构id变量
count_var number;--存放统计数字变量
oper_name_var varchar2(100);--操作名称
begin
returnflag := '1';--返回值初始化为1
orgseqflag := null;--初始化
skforgflag := null;--初始化
count_var := 0;--初始化
oper_name_var := null;--初始化
open pcursor;--打开游标 loop
fetch pcursor
into orgidCursor;--把游标数据放进pcursor变量
exit when pcursor%notfound; orgid_var := orgidCursor.orgid;--从orgidCursor变量取值到orgid_var
oper_name_var := orgidCursor.oper_name;--从orgidCursor变量取值到oper_name_var if (orgid_var is null) then--orgid_var是可能为空的 表里面t.orgid为空
null;
else
select count(1)
into count_var
from tssa_dsg.eosorg_t_organization b,
(select a.*
from tssa_dsg.bndict_t_dictionary a
where a.BUSINTYPEID = 'WH_CH_ORAPROPERTY'
and a.status = '0') a
where b.orgproperty = a.businid(+)
and b.orgid = orgid_var;--统计操作日志表的机构id是否在机构静态表里
if (count_var > 0) then--在里面
select t.orgseq
into orgseqflag
from tssa_dsg.eosorg_t_organization t
where t.orgid = orgid_var
--取orgseqflag
;
select a.businname
into skforgflag
from tssa_dsg.eosorg_t_organization b,
(select a.*
from tssa_dsg.bndict_t_dictionary a
where a.BUSINTYPEID = 'WH_CH_ORAPROPERTY'
and a.status = '0') a
where b.orgproperty = a.businid(+)
and b.orgid = orgid_var;--取组织分类 if (orgseqflag like '99999.7676.%' or skforgflag = '省客服' or
(skforgflag != '省客支' and skforgflag != '省层面' and
oper_name_var = '话务员追加信息')) then
null;
else
returnflag := null;--不满足id条件 置返回值为null
end if;
end if;
end if;
end loop;
close pcursor;
return returnflag;
end;
上面这个过程的作用就是根工单流程id 返回该工单是否仅仅经过某个特定组织机构的人处理的标志。
操作日志表的orgid有为空的情况。
if(orgid_var is null) 这个条件 推断假设为空 视该记录无效,不參与推断(业务要求)。
假设不加这个条件 (且没有
select count(1)
into count_var
from tssa_dsg.eosorg_t_organization b,
(select a.*
from tssa_dsg.bndict_t_dictionary a
where a.BUSINTYPEID = 'WH_CH_ORAPROPERTY'
and a.status = '0') a
where b.orgproperty = a.businid(+)
and b.orgid = orgid_var;--统计操作日志表的机构id是否在机构静态表里
)
以下这个语句
select t.orgseq
into orgseqflag
from tssa_dsg.eosorg_t_organization t
where t.orgid = orgid_var
查出来是没有结果的 就是无值
into orgseqflag
就会报错(调试会报错,直接执行不报错) 直接 跳出 loop 给 return 一个null 值 是不符合业务要求的。
select count(1)
into count_var
from tssa_dsg.eosorg_t_organization b,
(select a.*
from tssa_dsg.bndict_t_dictionary a
where a.BUSINTYPEID = 'WH_CH_ORAPROPERTY'
and a.status = '0') a
where b.orgproperty = a.businid(+)
and b.orgid = orgid_var;--统计操作日志表的机构id是否在机构静态表里
if (count_var > 0) then--在里面
上面这个条件作用跟if(orgid_var is null)是一样的 是忽略 操作日志表的机构id不在机构静态表里的情况。
oracle 让人抓狂的错误之 null值 与 无值(无结果)-开发系列(一)的更多相关文章
- 使用Google产品以来遇到的最糟糕、最霸道、最让人抓狂的设计
很久没有登录cnblogs@gmail.com这个邮箱,今天通过gmail.com登录了一下,登录后出现一个对话框要求设置性别与出生日期,而且必须要设置,不设置不让登录. 这个邮箱是我们网站用的是邮箱 ...
- C++雾中风景15:聊聊让人抓狂的Name Mangling
Name Mangling,直接翻译过来为名字改写 .它是深入理解 C++ 编译链接模型的必由之路. 笔者近期进行数据库开发工作时,涉及到MySQL客户端的编译链接的问题,通过重新厘清了之前理解一知半 ...
- 让人抓狂的MySQL安装-8.0.12版本
今天一个下午就做了一件事,把MySQL安装成功,安装的过程让人很狂躁.于是一边骂,一边查错,才把这个软件给安装成功了. 详细的安装步骤,这里就不赘述了.参见https://blog.csdn.net/ ...
- 轻松搞定word中让人抓狂的自动编号
在word中使用自动编号时,如果一级编号是2,想让其后面的二级编号自动编号为2.1.2.2--,三级编号自动编号为2.1.1.2.1.2--:且在该一级编号调整为3时,后面的二级编号和三级编号的第一位 ...
- 关于oracle下提示ORA-00904:Invalid identifier错误的问题
转自:https://blog.csdn.net/suleil1/article/details/49471549 今天在建表后对数据进行插入,遇到这个恶心人的ORA-00904:Invalid id ...
- 登陆Oracle,报oracle initializationg or shutdown in progress 错误提示
前两天,登陆Oracle,发现登陆不上去了,报”oracle initializationg or shutdown in progress 错误提示” 错误. 然后就想着怎么去解决,首先自己到win ...
- Oracle ORA-01033: ORACLE initialization or shutdown in progress 错误解决办法
Oracle ORA-01033: ORACLE initialization or shutdown in progress 错误解决办法 登陆数据库时提示 “ORA-01033”错误在命令窗口以s ...
- 那年曾让我哭笑不得抓狂的C语言
1.关于+=以及-= 这是两个运算符,但你否有过这种经历: int temp; char i ;i<MAX;i++) { ... temp=+; //这里本意是每次循环,temp都自增2,但是却 ...
- Oracle问题之ORA-12560TNS:协议适配器错误
Oracle问题之ORA-12560TNS:协议适配器错误 一.造成ORA-12560: TNS: 协议适配器错误的问题的原因有三个: 1.监听服务没有起起来.windows平台个一如下操作:开始-- ...
随机推荐
- IE兼容性开发的笔记
当前项目组开发的产品对外承诺支持IE9和IE11,但在推广应用过程中发现存在相当比例的用户实际上还在使用IE8.而这相当比例中的用户还包含了大部分的公司领导.为了满足公司内部各阶层人士体验我们产品的诉 ...
- 对 hiren bootcd 15.2 中的 XP 系统作了汉化, 同时支持中文输入法。提供下载
对 hiren bootcd 15.2 中的 XP 系统作了汉化, 同时支持中文输入法.提供下载 对该PE 中的 XP 系统作了汉化, 由于一个 中文字库 就要 10M 多:加之原系统过于精简,对中文 ...
- layui中select的注意
假如不在select 标签里面加上过滤lay-filter 那么你就算怎么绑定事件都是没有任何效果 页面上代码 js文件:
- C#之菜单控件、主窗体打开子窗体、GroupBox控件使用
一.背景 一年前有学习过C#,但没有在项目中去实际做APP,重新捡起来应用到项目中.我同事本来做好一个CANOPEN设备管理的界面,由于近期搜索了别人的开发的界面,我觉得有很多东西要重新安排,以及我已 ...
- ZZUACM 2015 暑假集训 round 01
A. Encoding Problem Description Given a string containing only 'A' - 'Z', we could encode it using t ...
- oracle学习之路(二)------数组类型/记录类型的使用
Oracle记录类型介绍 RECORD:用户自己定义数据类型,由单行多列的标量构成的复合数据类型.它将一个或多个标量封装成一个对象进行操作记录不能够总体拿来比較也不能够总体推断为空.能够总体拿来赋值. ...
- domino web app
近期在做个项目内容是:原企业的OA仅仅能在电脑桌面处理流程,不能在手机上处理审核功能,但随着企业需求,管理者需求在随时使用手机审核文档,达到及时处理文档及流程的及时性. 要求:1) ...
- Android中的帧动画与补间动画的使用
前言 在日常开发中,我们有时候须要一些好看的动画效果,这时能够充分利用Android提供的这几种动画来实现. Android提供了3种类型的动画: 补间动画:补间动画能够应用于View,让你能够定义一 ...
- 深入理解HTTP协议及原理分析之缓存(3种缓存机制)
3.2 缓存的实现原理 3.2.1什么是Web缓存 WEB缓存(cache)位于Web服务器和客户端之间. 缓存会根据请求保存输出内容的副本,例如html页面,图片,文件,当下一个请求来到的时候:如果 ...
- python3对序列求绝对值
http://www.cnblogs.com/itdyb/p/5731804.html 一开始我是这样写的,据说这样写python2是可以的: myList = [-1,2,-3,4,-5,6 ...