Oracle ORA-22908(NULL表值的参考)异常分析与解决方法

 更新时间:2013年11月22日 10:08:05   作者:  
这篇文章主要介绍了Oracle ORA-22908(NULL表值的参考)异常分析与解决方法,大家可以参考使用

场景如下:

--创建类型(type)create or replace type list_obj is table of number;--创建表结构create table test( name varchar2(30) primary key check(regexp_like(name,'^([a-z]|[0-9]|_)+$')), id number not null, version_list list_obj) nested table version_list store as version_list;

场景说明:类型 list_obj 相当一个元素为数字的列表。表 test 有三个字段,字段 name 为主键限制只能使用小写字母、数字、下划线组成的字符串;字段 id 是数字,限制为非空;字段 version_list 是类型为 list_obj 的嵌套表。

操作1:

--插入一条记录insert into test(name, id) values('mophee', 1);

查询结果如下:

目前 version_list 为空(注意,是 null),现在我们需要开始维护该字段:往 name='mophee' 的记录插入一个版本号20130403112459。语句如下:

--插入一个版本号insert into table(select version_list from test where name='mophee') values(20130403112459);

执行以上 insert 语句就报错了!

原因是什么?version_list 字段目前是 NULL,以上insert语句试图做这个动作:table(NULL),也就是要将NULL对象化成一个表。这事有违常理,ORACLE干不了!

那么怎么解决呢?version_list 字段之所以为NULL,是因为我们根本没对它进行初始化。那么,在insert之前先对其初始化不久能解决问题了吗?

方法一:在往 test 表 insert 的时候使用如下语句

--插入一条记录insert into test(name, id, version_list) values('mophee', 1, list_obj());

方法二:在往 version_list 插入版本号之前先对其进行初始化

--将 version_list 字段初始化为 list_obj 对象update test set version_list=list_obj() where name='mophee';

看下图:

这是在 pl/sql developer下的查询输出,注意 version_list 列数据单元格的背景色(与上方图片对比一下)已经不是淡黄色(此时字段值为null)!虽然查看 version_list 字段的内部内容依旧是没有一条记录,但是意义上是不一样的——初始化之前是 null,初始化之后才是 list_obj 对象。

 

相关文章

  • Oracle Users表空间重命名问题解决

    Oracle Users表空间重命名问题解决

    这篇文章主要介绍了Oracle Users表空间重命名问题,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-06-06
  • Oracle模糊查询的几种方法汇总【最后一种最优】

    Oracle模糊查询的几种方法汇总【最后一种最优】

    这篇文章主要介绍了Oracle模糊查询的几种方法汇总,针对每种方法小编给大家做了解析说明,在这推荐第三种,需要的朋友可以参考下
    2023-07-07
  • oracle日期分组查询的完整实例

    oracle日期分组查询的完整实例

    这篇文章主要给大家介绍了关于oracle日期分组查询的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • Oracle视图的创建、使用以及删除操作方法大全

    Oracle视图的创建、使用以及删除操作方法大全

    这篇文章主要给大家介绍了关于Oracle视图的创建、使用以及删除操作方法的相关资料,视图是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改,需要的朋友可以参考下
    2023-12-12
  • Oracle监听注册的实现

    Oracle监听注册的实现

    Oracle数据库的注册监听功能是Oracle数据库管理的一个重要组成部分,它允许数据库实例接收来自客户端请求,并且可以自动恢复数据库服务,感兴趣的可以了解一下
    2023-12-12
  • Oracle中检查外键是否有索引的SQL脚本分享

    Oracle中检查外键是否有索引的SQL脚本分享

    这篇文章主要介绍了Oracle中检查外键是否有索引的SQL脚本分享,本文给出了两个版本的脚本源码,一个查询所有用户,一个查询单用户,需要的朋友可以参考下
    2014-10-10
  • Oracle 11g Client客户端安装教程

    Oracle 11g Client客户端安装教程

    这篇文章主要为大家详细介绍了Oracle 11g Client客户端安装教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • Oracle安装监听器错误的解决方法

    Oracle安装监听器错误的解决方法

    这篇文章给大家介绍了oracle安装监听器错误的解决方法,非常不错,具有参考借鉴价值,需要的朋友参考下吧
    2017-09-09
  • Oracle实现细粒度访问控制的步骤

    Oracle实现细粒度访问控制的步骤

    细粒度访问控制是Oracle数据库中用于提供行级和列级安全控制的强大功能,本文主要给大家介绍了Oracle实现细粒度访问控制的步骤,并通过代码示例讲解的非常详细,需要的朋友可以参考下
    2024-09-09
  • Oracle数据库数据迁移完整解决步骤

    Oracle数据库数据迁移完整解决步骤

    我们常常需要对数据进行迁移,迁移到更性能配置更高级的主机OS上、迁移到远程的机房、迁移到不同的平台下,这篇文章主要给大家介绍了关于Oracle数据库数据迁移的相关资料,需要的朋友可以参考下
    2024-02-02

最新评论