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

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

admin2周前 (04-01)AI技术20

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上下文切换这三处,最容易漏检。写完记得跑边界用例:空输入、单元素、跨类型混合、函数提前返回。

相关文章

什么是LLM?看这一篇就够了!

一、全套AGI大模型学习路线 AI大模型时代的学习之旅:从基础到前沿,掌握人工智能的核心技能! 二、640套AI大模型报告合集 这套包含640份报告的合集,涵盖了AI大...

从入门到精通:前端开发之骡子快跑支持热点借势吗 骡子快跑节日营销文案生成|Duuu笔记

骡子快跑平台提供五步节日营销文案生成路径:一、调用内置32个节日模板库;二、输入热点事件触发动态生成;三、绑定自有素材库实现个性化延展;四、多角色视角协同输出;五、接入微信生态直发并校验合规性。 ☞...

前端开发高级应用:Minimax视频生成提示词中文还是英文好实战案例|Duuu笔记

优先使用英文提示词,因其更契合模型训练语料并能稳定触发视觉特征;其次可采用中英混合策略兼顾文化专有名词;纯中文适用于强本土化场景;最终需通过多指标对比验证最优语言形式。 ☞☞☞AI 智能聊天, 问答...

大模型超详细盘点!常用的大模型及其优缺点、有潜力的大模型、国内大模型行业落地的现况、国内大模型优势、挑战与前景

除了上述大模型外,还有一些有潜力的大模型值得关注,如: 华为云——盘古大模型 :华为基于Transformer架构打造的超大规模人工智能模型,具有万亿级别参数,可以在图像、语音...

深入理解AI:避坑实战:如何纠正 在执行 Prompt 时的幻觉与逻辑错误完全指南|Duuu笔记

有效纠偏AI幻觉的关键在于任务设计源头切断错误条件:明确角色权限禁令、硬性规定输出格式、使用精确动词、分步推理并嵌入检查点、提供带纠错痕迹的小样本示例、设置输出自检环节。 ☞☞☞AI 智能聊天, 问...

从入门到精通:前端开发之Minimax视频生成硬件要求 Minimax对手机电脑配置要求|Duuu笔记

MiniMax视频生成问题多因硬件不兼容或性能不足,需按设备类型满足对应配置:手机端需Android 10+/iOS 15.0+及指定芯片;电脑端重浏览器版本与GPU驱动;本地API调用需i5-840...

发表评论

访客

看不清,换一张

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