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

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

admin2个月前 (04-05)AI技术55

在生产环境中优化前端,本文分析

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大...

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

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

推荐10个AI人工智能技术网站

除了研究和开发人工智能技术,OpenAI还积极参与人工智能伦理和安全的研究和探讨。 认为,人工智能技术的发展必须遵循伦理和法律的规范,以确保人工智能的应用不会对人类带来负面影响。...

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

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

深入理解前端开发:Minimax 视频生成中负面提示词(Negative Prompt)写法完全指南|Duuu笔记

Minimax视频生成中负面提示词需用英文、逗号分隔,支持权重调节(如(blurry:1.3)),按构图/主体/画质/风格四类精简选取,禁用not/no/中文及违规词,须通过A/B测试验证有效性。...

AI高级应用:Perplexity 怎么写用户手册 Perplexity 产品帮助文档生成【技术】实战案例|Duuu笔记

Perplexity AI用户手册需基于API元数据、真实UI截图、典型场景示例、响应字段解析及动态调试指令五步构建:一调用API获取参数与错误码;二标注网页端搜索框、引用图标等组件;三设计信息检索、...

发表评论

访客

看不清,换一张

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