Oracle-33-变量%type、变量%rowtype、记录类型、记录表类型

2023-10-18 16:30

本文主要是介绍Oracle-33-变量%type、变量%rowtype、记录类型、记录表类型,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、%type变量

当用户事先并不知道检索的数据列的数据类型,可以使用%type定义变量。

比如:SQL>id emp.empno%type 就是将emp表中empno列的数据类型为变量id的数据类型

 

1:练习%type定义未知类型的变量。

解:用student表做:




二、%rowtype变量

%rowtype变量一次可以存储一行数据。

2:练习%rowtype变量。

解:注意下图中的程序:




三、复合类型变量(存储多行数据,可以理解为数组)

1.复合变量

与标量变量对应的就是复合变量。

 

2.复合变量分为以下两种类型

(1)记录类型

记录类型复合变量中可以存储多个标量值,结构与行相似;可以存储由多个列值组成的一行数据。

语法格式:


type 变量名 is record(

…………………………

…………………………

…………………………

);省略号部分是需要存储的数据

 

比如以下程序:


declare

      type emp_record is record(

           id emp.empno%type,

           name emp.empno%type

      );

a emp_record;——定义变量a,类型record,这里有人理解为给emp_record取别名(这有待斟酌)。

begin

      select empno,ename into a from emp where empno = 7935;

      dbms_output.put_line(a.id);

      dbms_output.put_line(a.name);

end;


【注意】type变量名 is record之后括号内的代码,与create table一样,除最后一行以外每行逗号结尾,最后一行末尾不要任何标点符号,最后一行输入完毕,回车,打上左括号、分号,回车结束。标点必须这么做,否则报错。

 

3:练习记录类型复合变量。

解:注意下图中的程序:




(2)记录表类型

该变量类型允许用户在代码中使用“表”,以便存储多个行数据。记录表类型是对记录类型的扩展,可以处理多个记录或多行数据

 

为什么使用记录表类型

答:因为一个记录类型变量只可以存储查询语句返回的一行数据,这就限制了select语句只能返回一行。如果select语句返回多行数据,那么就可以使用记录表类型。所以记录表类型它可以处理或是存储返回的多行数据。

 

语法格式:


type table_name is table of data_type [not null] index by binary_integer;


其中index by binary_integer是该记录表的下标数据类型(类似于数组下标)或称为记录表的长度,table_name是定义记录表名,data_type是定义记录表类型中存储数据的类型。

 

比如如下程序:


declare

      type table_a is table of varchar2(20) index by binary_integer;

      a table_a;

begin

      a(1) := ‘第一个变量值’;

      a(2) := ‘第二个变量值’;

      dbms_output.put_line(a(1));

      dbms_output.put_line(a(2));

end;

 

4:练习记录表类型的复合变量

解:注意下图中的程序:




记录表类型存储值的方式

有一个索引来标识这一行记录,图解如下:




【注意】

(1)索引从1开始,而不是从0开始;

 

记录表提供的方法几种:

1count返回记录表中记录的数量;

2delete删除记录表中的记录,比如a.delete(2)是删除记录表中的第二个值;

3first返回记录表中最小索引值;

4last返回记录表中最大的索引值;

5next返回记录表变量中的下一个索引,当使用该方法的时候,需要传递一个索引值。

 

5:练习以上记录表提供的方法。

解:注意下图中的程序:




由此可见,t.delete(2)删除记录表中第二个数据后记录表总长度不变,原来是5,现在还是5,且后面记录不会前进一个,即原来t(4)是d,现在还是d。

这篇关于Oracle-33-变量%type、变量%rowtype、记录类型、记录表类型的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/233795

相关文章

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

PLsql Oracle 下载安装图文过程详解

《PLsqlOracle下载安装图文过程详解》PL/SQLDeveloper是一款用于开发Oracle数据库的集成开发环境,可以通过官网下载安装配置,并通过配置tnsnames.ora文件及环境变... 目录一、PL/SQL Developer 简介二、PL/SQL Developer 安装及配置详解1.下

oracle如何连接登陆SYS账号

《oracle如何连接登陆SYS账号》在Navicat12中连接Oracle11g的SYS用户时,如果设置了新密码但连接失败,可能是因为需要以SYSDBA或SYSOPER角色连接,解决方法是确保在连接... 目录oracle连接登陆NmOtMSYS账号工具问题解决SYS用户总结oracle连接登陆SYS账号

Oracle数据库如何切换登录用户(system和sys)

《Oracle数据库如何切换登录用户(system和sys)》文章介绍了如何使用SQL*Plus工具登录Oracle数据库的system用户,包括打开登录入口、输入用户名和口令、以及切换到sys用户的... 目录打开登录入口登录system用户总结打开登录入口win+R打开运行对话框,输php入:sqlp

查询Oracle数据库表是否被锁的实现方式

《查询Oracle数据库表是否被锁的实现方式》本文介绍了查询Oracle数据库表是否被锁的方法,包括查询锁表的会话、人员信息,根据object_id查询表名,以及根据会话ID查询和停止本地进程,同时,... 目录查询oracle数据库表是否被锁1、查询锁表的会话、人员等信息2、根据 object_id查询被

解决Spring运行时报错:Consider defining a bean of type ‘xxx.xxx.xxx.Xxx‘ in your configuration

《解决Spring运行时报错:Considerdefiningabeanoftype‘xxx.xxx.xxx.Xxx‘inyourconfiguration》该文章主要讲述了在使用S... 目录问题分析解决方案总结问题Description:Parameter 0 of constructor in x

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据