当前位置:首页 > AI技术 > 正文内容

前端开发 如何使用PL/SQL嵌套表 初始化赋值与MULTISET运算符应用|Duuu笔记

admin6天前AI技术14

PL/SQL嵌套表变量声明后必须显式初始化,否则EXTEND或下标赋值报ORA-06531;MULTISET运算要求类型完全一致;SQL中使用需TABLE(CAST(...));函数返回前须确保初始化,调用方需先判NULL再COUNT。

PL/SQL嵌套表变量声明后必须显式初始化才能赋值

直接声明嵌套表类型变量却不初始化,后续用

extend

或下标赋值会报

ora-06531: reference to uninitialized collection

。这不是语法错误,是运行时陷阱——pl/sql不会自动为你分配内存空间。

声明后立刻用

:= my_nested_table_type()

(空构造函数)初始化,这是最安全的做法

如果想带初始值,直接写

:= my_nested_table_type

(1, 2, 3)

,括号里是元素列表,类型必须严格匹配

不能用

NULL

初始化嵌套表变量,

my_var := NULL

会让它保持未初始化状态,后续任何访问都崩

MULTISET UNION/INTERSECT/EXCEPT 要求类型完全一致

MULTISET

运算符不是“看起来像就行”,左右操作数必须是同一嵌套表类型(包括 schema、精度、字符集等),连是否

NOT NULL

都得对齐。类型不匹配会报

ORA-00932: inconsistent datatypes

,而不是更友好的提示。

别指望

NUMBER

PLS_INTEGER

自动兼容,哪怕值域一样也得显式转换

如果两个嵌套表来自不同包或不同作用域,即使结构一模一样,也得用

CAST

强转成同一个类型名,比如

CAST(t1 AS my_pkg.t_nested)

MULTISET EXCEPT

会去重并忽略重复次数(即集合语义),不是数组差集;要保留频次差异得自己写循环

在 SQL 语句中使用嵌套表需配合 TABLE() 函数和 CAST

PL/SQL 里的嵌套表变量不能直接塞进

SELECT ... IN (SELECT ...)

WHERE col MEMBER OF

,必须先转成 SQL 可识别的格式。否则报

ORA-22905: cannot access rows from a non-nested table item

白瓜AI

白瓜AI,一个免费图文AI创作工具,支持 AI 仿写,图文生成,敏感词检测,图片去水印等等。

下载

TABLE(CAST(my_plsql_var AS my_nested_table_type))

是标准写法,

CAST

不可省略

如果嵌套表元素是对象类型,确保该对象类型已用

CREATE OR REPLACE TYPE

在 SQL 层注册,PL/SQL 包里定义的类型不行

性能上,大嵌套表走

TABLE()

会产生临时段,频繁调用建议改用绑定变量 + 临时表,别硬扛

嵌套表作为函数返回值时,调用方必须处理空集合情况

函数返回嵌套表,但内部逻辑可能没初始化就直接

RETURN

,调用方拿到的是未初始化变量,不是空集合。这时候在 SQL 中用

TABLE()

会崩,在 PL/SQL 中用

COUNT

会报错,而不是返回 0。

函数末尾务必检查:如果逻辑路径可能无数据,显式

RETURN my_type()

(空构造)

调用方别信

IF my_var.COUNT > 0 THEN

,先做

IF my_var IS NOT NULL THEN

判断

MULTISET

运算时,任一操作数为

NULL

,整个结果就是

NULL

,不是空集合——这点和普通数值运算逻辑完全不同

类型一致性、初始化时机、SQL/PLSQL上下文切换这三处,最容易漏检。写完记得跑边界用例:空输入、单元素、跨类型混合、函数提前返回。

相关文章

【大数据分析 | 深度学习】在Hadoop上实现分布式深度学习

一、Submarine(Hadoop生态系统) (一)Submarine 介绍 (三)Submarine 属于 Hadoop 生态系统 (四)Submarine 官网版...

Unity 机器学习 基础

ML-Agents 资产导入 Unity 场景创建 Unity 代码部分 Anaconda 执行 rollerball_config.yaml 机器学习逻辑处理...

神经网络中的单层神经网络

神经网络是一种模拟人脑的神经网络以期能够实现类人工智能的机器学习技术。人脑中的神经网络是一个非常复杂的组织。成人的大脑中估计有1000亿个神经元之多。 看一个经典的神经网络。这是一个包...

跨平台机器学习:ML.NET架构及应用编程

平台上的一个机器学习框架,它提供了一套丰富的算法和工具,使得开发人员可以轻松地构建和部署机器学习模型。支持多种编程语言,包括等,这使得它成为跨平台机器学习的理想选择。的架构主要包括三个部分:数据读取、...

一文讲清神经网络、BP神经网络、深度学习的关系

人工神经网络中的顶级代表。往往说《神经网络》就是指《BP神经网络》。 大家研究着各种神经网络,研究得不亦乐乎, 来了两个家伙Romelhart 和Mcclelland,...

什么是人工智能 ?

您可以使用 ML 训练 AI,使其精确、快速地执行任务。这可以通过自动化员工感到吃力或厌烦的业务部分来提高运营效率。同样,您可以使用 AI 自动化来腾出员工资源,用于更复杂和更具创造性的工作。...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。