很烦躁,烦躁的很,总结一下。

先简单的说下:

NULL   : 不确定的东西

无       :没有东西

复杂的见下文。。。。。。。

一 、null值

下面举个最简单的例子,平常工作当中肯定比这个sql复杂的多,在这只是把这个易错点呈现出来,他可能是一个复杂sql出错的小的 不容易被发现的一个问题。

上面是一个很简单表的所有数据。area_num 区域编码 area_name 区域名称 delflag 有无效标识 1有效 0无效(其中淮北 和宣城的delflag为null)。

现在想找出有效的那些区域信息,所以用下面的语句:

上面的结果中没有淮北和宣城 跟预想中的不一样 一开始以为是 delflag不为0的所有应该都被查询出来 包括淮北和宣城。

事实上 淮北和宣城 delflag的字段是 null值。在oracle里面null值得概念:

NULL是数据库中特有的数据类型,当一条记录的某个列为NULL,则表示这个列的值是未知的、是不确定的。既然是未知的,就有无数种的可能性。因此,NULL并不是一个确定的值。

所以null值(不确定的值) 并不符合 !='0' 这个 条件。同样下面语句也是这样。

二、无结果

无结果其实就是一个select查询没有结果集(不是null,而是没有结果)

结果为null:

无结果:

表面看很的清楚明白,但是到了实际应用中可能 会容易搞错。

下面是示例的存储过程:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
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) 这个条件 判断如果为空 视该记录无效,不参与判断(业务要求)。

如果不加这个条件 (且没有

1
2
3
4
5
6
7
8
9
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是否在机构静态表里

下面这个语句

1
2
3
4
select t.orgseq
          into orgseqflag
          from tssa_dsg.eosorg_t_organization t
         where t.orgid = orgid_var

查出来是没有结果的 就是无值

1
into orgseqflag

就会报错(调试会报错,直接运行不报错) 直接 跳出 loop 给 return 一个null 值 是不符合业务要求的。

1
2
3
4
5
6
7
8
9
10
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不在机构静态表里的情况。

SQL 中【NULL】和【无】烦躁的问题的更多相关文章

  1. sql中NULL的问题

    sql中NULL的问题   今天一不小心在sql中写出以下脚本 select defaultPositionId from TableName where UserId=1100528 and def ...

  2. sql中null 和 ‘’(空字符串)

    sql 中 null  和 空字符串的区别方式 在Silverlight中  数据库 需要与实体类进行映射, 假如实体类不允许为null,则 select '' as 列名  from  表名字:   ...

  3. SQL中null比较的雷区

    SQL中遇到null要格外小心! oracle最坑: oracle中在可为null的字段上做逻辑关系运算要格外小心,如 <>,>,=,<,任何与null的运算结果都返回fals ...

  4. SQL中NULL值

    SQL的表达式,除了IS NULL和NOT NULL以外,只要出现NULL值结果都为FALSE 简单的例子: SELECT * FROM table WHERE name!='abc' 只要name值 ...

  5. SQL中NULL的妙用

    商品表Products 库房表WarehouseDistrict 库存表WarehouseStock 一般写法 ;WITH stock AS ( SELECT DistrictId, ProductI ...

  6. SQL语句中=null和is null

    平时经常会遇到这两种写法:IS NOT NULL与!=NULL.也经常会遇到数据库有符合条件!=NULL的数据,但是返回为空集合.实际上,是由于对二者使用区别理解不透彻. 默认情况下,推荐使用 IS ...

  7. sql server中NULL导入decimal字段时报错

    sql server中NULL导入decimal字段时报错 在导入CSV文件时,如果decimal字段为null值,导致文本文件入库时失败. 错误现象 构造例子 新建一张表,包含decimal字段. ...

  8. SQL中的Null深入研究分析

    SQL中的Null深入研究分析 虽然熟练掌握SQL的人对于Null不会有什么疑问,但总结得很全的文章还是很难找,看到一篇英文版的, 感觉还不错. Tony Hoare 在1965年发明了 null 引 ...

  9. SQL中空值与NULL区别

    很多人都有过这样的问题吧   在SQL中填充空值与NULL有什么区别 现在我以一个实例给大家分享一下自己的想法  恳请大家给予批评也指正 谢谢 创建一个监时表 CREATE TABLE #temp ( ...

随机推荐

  1. 基于ELK的简单数据分析

    原文链接: http://www.open-open.com/lib/view/open1455673846058.html 环境 CentOS 6.5 64位 JDK 1.8.0_20 Elasti ...

  2. iOS - Core Animation(核心动画)

    Core Animation,中文翻译为核心动画,它是一组非常强大的动画处理API,使用它能做出非常炫丽的动画效果,而且往往是事半功倍.也就是说,使用少量的代码就可以实现非常强大的功能.Core An ...

  3. vsftpd java程序无法创建和切换目录

    # Example config file /etc/vsftpd/vsftpd.conf # # The default compiled in settings are fairly parano ...

  4. python操作数据库PostgreSQL

    1.简述 python可以操作多种数据库,诸如SQLite.MySql.PostgreSQL等,这里不对所有的数据库操作方法进行赘述,只针对目前项目中用到的PostgreSQL做一下简单介绍,主要包括 ...

  5. flask BytesIO() 多个文件打包下载 zipfile

    使用zipfile模块可以将多个文件打包成zip文件进行下载,但是常规的操作方式会在服务器磁盘上生成一个zip文件占用磁盘空间. 后引入BytesIO将文件写入到内存中然后下载: def dl_pla ...

  6. [LintCode] Invert Binary Tree 翻转二叉树

    Given n points on a 2D plane, find the maximum number of points that lie on the same straight line. ...

  7. 微信都在用的移动敏捷测试方法和工具|视频+PPT

    本文是腾讯优测总监雷彬在MPD2016 北京站上的演讲视频.他详细讲述了腾讯多年来在实践敏捷研发过程中测试的优化之路,为测试角色(包括测试工程师和开发自测)提供敏捷作业的思路.点击此处观看视频.时长5 ...

  8. c++之list的用法

    list同vector一样是c++中的一个模板类.关于它的详细内容可查看c++的文档 http://www.cplusplus.com/reference/list/list/ C++中list的使用 ...

  9. 0005python中的静态方法和类方法

    #!/usr/bin/env python# coding=utf-8 __metaclass__ = type class StaticMethod: @staticmethod def foo() ...

  10. 内核futex的BUG导致程序hang死问题排查

    https://mp.weixin.qq.com/s/sGS-Kw18sDnGEMfQrbPbVw 内核futex的BUG导致程序hang死问题排查 原创: 王领先 58架构师 今天   近日,Had ...