Oracle PLSQL INDEX BY Binary_Integer 测试

本文深入探讨了PL/SQL编程中非标号数组和标号数组的使用方法和特性,包括声明、赋值、初始化及下标访问等关键操作。通过实例展示了两者在内存分配、初始化过程以及使用场景上的差异,旨在帮助开发者更好地理解并应用这些数组类型。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[转自] http://blog.chinaunix.net/uid-14669803-id-2921539.html


DECLARE

TYPE t_list_1 IS TABLE OF VARCHAR2(1024) ; -- 非标号,需要动态初始化,动态extend
TYPE t_list_2 IS TABLE OF VARCHAR2(1024) INDEX BY Binary_Integer; -- 标号数组,不需要动态申请

-- 非标号数组
v_list_11 t_list_1 := t_list_1('11A','11B'); -- 声明时赋初值
v_list_12 t_list_1 ;

-- 标号数组
v_list_21 t_list_2 ;

	/* 标号数组声明不能赋初值
	v_list_21 t_list_2 := t_list_2('A','B');
	*/

BEGIN
dbms_output.put_line(v_list_11(1));

	/* 报错,需要初始化
	v_list_12(1):='1A';
	*/

-- 初始化
v_list_12 := t_list_1();
v_list_12.extend;
v_list_12(1) :='12A';
dbms_output.put_line(v_list_12(1));

-- 标号数组不需要初始化,下标从1开始
v_list_21(1) :='21A';
dbms_output.put_line(v_list_21(1));
-- 并且可以指定下标赋值
v_list_21(100) :='2100A';

dbms_output.put_line(v_list_21(100));
dbms_output.put_line(v_list_21.count);

END
;
/

11A
12A
21A
2100A
2
PL/SQL procedure successfully completed


转载于:https://www.cnblogs.com/pekkle/p/6568785.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值