news 2026/4/27 5:29:17

GBase8s集合类型之关联数组简介

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
GBase8s集合类型之关联数组简介

GBase 8s兼容oracle的PL/SQL编程语言,PL/SQL 语法需要显式设置环境变量SQLMODE为’ORACLE’后才能生效,默认情况下8s的SQLMODE为’GBASE’,此时不支持 PL/SQL 语法。本文将介绍GBase 8s兼容oracle模式中的关联数组类型,包括它们的使用场景、特点以及如何有效利用它们来提高数据库操作的效率。


兼容oracle的集合类型包括三种,分别是关联数组类型、变长数组类型、嵌套表类型,本文主要讲述关联数组类型及其变量的使用。关联数组的元素数量未指定,索引类型可以为字符串或者PLS_INTEGER,可以在PLSQL块中或者包中进行定义。


关联数组是一组键值对,每个键都是一个唯一的索引,用于定位与语法variable_name(index)相关联的值。


1.语法

type population is table of int index by varchar(10);

2.特点

  • 索引的数据类型可以是字符串类型(VARCHAR2、VARCHAR、string或LONG)或PLS_INTEGER。
  • 索引是按排序顺序存储的,而不是按创建顺序存储的。对于字符串类型,排序顺序由初始化参数NLS_sort和NLS_COMP决定。
  • 不需要初始化。


3.与数据库表的不同点:

  • 关联数组不需要磁盘空间或网络操作
  • 关联数组无法使用dml语言进行操作


4.关联数组的比较

  • 不能与NULL进行比较
  • 不支持变量直接比较:v1=v2
  • 只支持变量元素比较:v1(1)=v2(1)


5.示例

DECLARE TYPE type_1 IS TABLE OF NUMBER INDEX BY VARCHAR2(64); v1 type_1; i VARCHAR2(64); BEGIN v1('Smallville') := 2000; v1('Midland') := 750000; v1('Megalopolis') := 1000000; v1('Smallville') := 2001; i := v1.first; while i is not null loop dbms_output.put_line('values of ' || i || ' is ' || v1(i)); i := v1.next(i); end loop; end; /

运行结果:
Population of Megalopolis is 1000000
Population of Midland is 750000
Population of Smallville is 2001

--关联数组类型和嵌套表类型作为存储过程的out参数,并应用在package中 drop table if exists tab1; create table tab1(id int,name varchar(10)); create or replace package pkg1 as type t1 is table of tab1.id%type; type t2 is table of tab1.name%type index by varchar(5); procedure p1(c out t1); procedure p2(c out t2); end; / create or replace package body pkg1 as procedure p1 (c out t1) is a tab1%rowtype; -- c t1 := t1(100,200); begin c := t1(100,200); end; procedure p2 (c out t2) is a tab1%rowtype; begin c ('var') := 'Jack'; end; end; / --调用嵌套表作为out参数的procedure declare b pkg1.t1:=pkg1.t1(10,20); begin pkg1.p1(b); dbms_output.put_line(b(1)); end; / 100 --调用关联数组作为out参数的procedure declare c pkg1.t2; begin pkg1.p2(c); dbms_output.put_line(c('var')); end; / Jack

通过本文的介绍GBase 8s 中关联数组的使用方法、特点及其在 PL/SQL 编程中的应用。关联数组提供了一种灵活的方式来存储和操作一组键值对,适用于多种场景。希望这些内容能帮助你在实际开发中更高效地利用关联数组。如果你在使用过程中遇到任何问题,欢迎随时在社区中提问,我们在这里为你提供支持!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/22 23:15:59

MATLAB图像增强:开启视觉盛宴之旅

MATLAB图像增强代码 代码些许复杂,由本人一个朋友编写 是机器视觉和图像增强领域的应用,有gui界面,可以载入原图和参照强化的图像,读取参照图像的RGB或者HSV 分量,并强化原图像, 运行,corrction…

作者头像 李华
网站建设 2026/4/25 12:02:42

基于SpringBoot的爱心商城系统毕业设计源码

博主介绍:✌ 专注于Java,python,✌关注✌私信我✌具体的问题,我会尽力帮助你。一、研究目的本研究旨在设计并实现一个基于SpringBoot框架的爱心商城系统,以满足现代电子商务领域对于高效、安全、易用的在线购物平台的需求。具体研究目的如下&…

作者头像 李华
网站建设 2026/4/24 23:01:15

基于SpringBoot的甘肃旅游服务平台毕业设计源码

博主介绍:✌ 专注于Java,python,✌关注✌私信我✌具体的问题,我会尽力帮助你。一、研究目的本研究旨在构建一个基于SpringBoot框架的甘肃旅游服务平台,以实现甘肃旅游资源的数字化管理和智能化服务。具体研究目的如下:提高甘肃旅游…

作者头像 李华
网站建设 2026/4/25 12:02:41

【dz-1008】基于单片机的环境监测系统设计

摘要 随着人们对生活环境质量关注度的不断提升,对环境参数的精准监测与及时预警变得尤为重要。传统的环境监测方式多依赖人工采样和实验室分析,不仅耗时费力、响应滞后,还存在数据获取不及时、监测范围有限等问题,难以满足实时、…

作者头像 李华
网站建设 2026/4/27 0:48:29

【dz-1012】小型无士栽培自动控制系统设计与实现

摘要 在无土栽培领域,环境参数与营养液状态的精准调控对作物生长质量与产量起着决定性作用。传统无土栽培管理多依赖人工巡检和经验调节,存在参数控制滞后、营养液配比失衡、资源浪费等问题,难以满足精细化种植的严苛需求。 基于 STM32F103…

作者头像 李华
网站建设 2026/4/25 13:22:21

绿色工厂与上市公司匹配数据(2017-2023)

1729顶刊收割机!绿色工厂与上市公司匹配数据(2017-2023)数据简介2016年工业和信息化部(以下简称工信部)启动了第一批绿色制造体系示范建设项目,该项目涵盖绿色工厂、绿色产品、绿色园区、绿色供应链等多方面…

作者头像 李华