问题描述
有多少种方法来命名流水线表函数的输出列?
我的理解是唯一的方法是通过这样的记录类型:
我曾希望可以用光标列来命名它们,但这导致列被命名为: ATTR_1,ATTR_2,ATTR_3等。
我的理解是唯一的方法是通过这样的记录类型:
CREATE PACKAGE blah_blah_blah IS TYPE abc_rec IS RECORD (ID NUMBER, SUBJECT VARCHAR2(30), BODY VARCHAR2(4000)); TYPE abc_rec_table IS TABLE OF abc_rec; FUNCTION xyz RETURN abc_rec_table PIPELINED; END blah_blah_blah; SELECT * FROM blah_blah_blah.xyz; ID SUBJECT BODY == =========== ======== 1 Subject One Body One 2 Subject Two Body Two 3 Subject Three Body Three复制
我曾希望可以用光标列来命名它们,但这导致列被命名为: ATTR_1,ATTR_2,ATTR_3等。
CREATE PACKAGE blah_blah_blah IS CURSOR C1 IS SELECT CAST(ID AS NUMBER) AS ID, CAST(SUBJECT AS VARCHAR2(30)) AS SUBJECT, CAST(BODY AS VARCHAR2(4000)) AS BODY FROM; TYPE abc_rec_table IS TABLE OF C1%ROWTYPE; FUNCTION xyz RETURN abc_rec_table PIPELINED; END blah_blah_blah; ATTR_1 ATTR_2 ATTR_3 ====== ============= ======== 1 Subject One Body One 2 Subject Two Body Two 3 Subject Three Body Three 复制
专家解答
我不知道有什么方法可以覆盖使用基于光标的数据类型时获得的ATTR * 名称。
所以我相信你必须使用记录 (或对象类型),就像你的第一个例子一样。
所以我相信你必须使用记录 (或对象类型),就像你的第一个例子一样。
文章转载自ASKTOM,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【专家有话说第五期】在不同年龄段,DBA应该怎样规划自己的职业发展?
墨天轮编辑部
1295次阅读
2025-03-13 11:40:53
Oracle RAC ASM 磁盘组满了,无法扩容怎么在线处理?
Lucifer三思而后行
780次阅读
2025-03-17 11:33:53
Oracle+Deepseek+Dify 实现数据库数据实时分析
bicewow
705次阅读
2025-03-06 09:41:49
【ORACLE】ORACLE19C在19.13版本前的一个严重BUG-24761824
DarkAthena
569次阅读
2025-03-04 14:33:31
Oracle避坑指南|同名表导出难题:如何精准排除指定用户下的表?
szrsu
534次阅读
2025-03-05 00:42:34
2月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
457次阅读
2025-03-13 14:38:19
Ogg23ai高手必看-MySQL Innodb Cluster跟oracle的亲密接触
曹海峰
454次阅读
2025-03-04 21:56:13
【ORACLE】char类型和sql优化器发生的“错误”反应
DarkAthena
406次阅读
2025-03-04 23:05:01
什么,oracle 主机用户被删了?原来是虚惊一场!
Lucifer三思而后行
405次阅读
2025-03-03 21:12:09
Oracle 如何修改 db_unique_name?强迫症福音!
Lucifer三思而后行
348次阅读
2025-03-12 21:27:56