Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 432|回复: 0

oracle数据中 模糊查找关键字like存在问题解决

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-7-7 21:48:56 | 显示全部楼层 |阅读模式

    oracle中查询关键字 like,当我用like执行模糊查找是,发现数据量不对,表的结构如下:

    -- Create table
    create table NEOERP
    (
      ID                   NUMBER(22) not null,
      PRODUCTNAME          NVARCHAR2(100) default ' ',
      CT_SMP_SPECIFICATION NVARCHAR2(100) default ' ',
      TYPENAME             NVARCHAR2(50),
      UNIT                 NVARCHAR2(30) default ' ',
      STORECODE            NVARCHAR2(100) default ' ',
      ROOMCODE             NVARCHAR2(100) default ' ',
      SAMPTMPLID           NVARCHAR2(100),
      CT_BELONG            NVARCHAR2(100) default ' ',
      CT_MANUFACTURE       NVARCHAR2(100),
      CT_EXPORTER_PLACE    NVARCHAR2(100),
      REMARK               NVARCHAR2(200),
      LOGINDATE            DATE default sysdate,
      CT_SMP_TYPE          NVARCHAR2(100),
      SAMPLENAME           NVARCHAR2(200),
      SAMPLEDESCRIPTION    NVARCHAR2(200),
      STARTDATE            DATE,
      STATUS               NVARCHAR2(2) default 'F',
      REMOVE_DATE          DATE,
      TIMETYPE             NVARCHAR2(10),
      REPORTDATE           NUMBER(22),
      TIMEVALUE            NUMBER(22)
    )
    tablespace VGSM
      pctfree 10
      initrans 1
      maxtrans 255
      storage
      (
        initial 64K
        minextents 1
        maxextents unlimited
      );
    -- Add comments to the columns 
    comment on column NEOERP.PRODUCTNAME
      is '产品名称';
    comment on column NEOERP.CT_SMP_SPECIFICATION
      is '规格';
    comment on column NEOERP.TYPENAME
      is '类别名称';
    comment on column NEOERP.UNIT
      is '单位';
    comment on column NEOERP.STORECODE
      is '存货编码';
    comment on column NEOERP.ROOMCODE
      is '物料编码';
    comment on column NEOERP.SAMPTMPLID
      is '样品模版id';
    comment on column NEOERP.CT_BELONG
      is '归属地';
    comment on column NEOERP.CT_MANUFACTURE
      is '生产地';
    comment on column NEOERP.CT_EXPORTER_PLACE
      is '出口地';
    comment on column NEOERP.REMARK
      is '备注';
    comment on column NEOERP.CT_SMP_TYPE
      is '样品类型';
    comment on column NEOERP.SAMPLENAME
      is '样品名称';
    comment on column NEOERP.SAMPLEDESCRIPTION
      is '样品描述';
    comment on column NEOERP.STARTDATE
      is '起始时间';
    comment on column NEOERP.STATUS
      is 'f可用 状态';
    comment on column NEOERP.REMOVE_DATE
      is '删除时间';
    comment on column NEOERP.TIMETYPE
      is '年月日';
    comment on column NEOERP.REPORTDATE
      is '要求报告日期';
    comment on column NEOERP.TIMEVALUE
      is '有效期';
    -- Create/Recreate primary, unique and foreign key constraints 
    alter table NEOERP
      add constraint PK_ERP_ID primary key (ID)
      using index 
      tablespace VGSM
      pctfree 10
      initrans 2
      maxtrans 255
      storage
      (
        initial 64K
        minextents 1
        maxextents unlimited
      );

    当我用SELECT * FROM NEOERP WHERE ROOMCODE LIKE '%%',来查询时候,数据一直存在问题,查处的数据量与期望的数据量不同,

    经查,是当roomcode为null造成的,

    当我用SELECT * FROM NEOERP WHERE ROOMCODE IS NULL 来查询发现这个查询的结果是我所缺少的数据信息。

    null的含义,在我们不知道具体有什么数据,也即未知,称他为空,oracle中,含有空值的表列长度为零。

    等价于没有任何值,是未知数,null与0,空字符串,空格不同,对空值做运算,结果仍然是空值,oracle提供了处理空值函数nvl,比较时候用 is null或者 is not null.

    通过以上说明,通过SELECT * FROM NEOERP WHERE ROOMCODE LIKE '%%'查询不到值为null的数据。

    对上面sql语句进行修改后,既可以完成所需功能:

    SELECT * FROM NEOERP WHERE NVL(ROOMCODE,0) LIKE '%%'

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-22 19:02 , Processed in 0.061427 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表