热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

Oracle中%TYPE和%ROWTYPE说明

Oracle中%TYPE和%ROWTYPE说明1.使用%TYPEwww.2cto.com在许多情况下,变量应该拥有与表列相同的类型。例如,emp表的name列的类型为VARCHAR2(20),我们可以使用硬编码写法声明一个变量:DECLAREvar_N...SyntaxHighl

Oracle中%TYPE和%ROWTYPE说明
 
1. 使用%TYPE   www.2cto.com  
 
在许多情况下,变量应该拥有与表列相同的类型。例如,emp表的name列的类型为VARCHAR2(20),我们可以使用硬编码写法声明一个变量: 
 
DECLARE 
       var_Name VARCHAR2(20); 
 
这样可以实现,但是如果name列的定义改变了,比如将name字段的类型变为VARCHAR2(50),那就会导致所有使用这个变量的PL/SQL代码都必须进行修改。而且如果你有很多的PL/SQL代码,这种处理可能是灰常繁琐和容易出错的,这时,你可以使用”%TYPE”属性这种类型硬性编码,类似在java开发中,我们习惯将一些常量进行固定的定义,比如public static final String arg = 'Your Name'; 
 
例如: 
 
DECLARE 
       var_name emp.name%TYPE; 
 
   通过使用%TYPE,var_name变量将同emp表的name列的类型绑定,这样每次匿名块、命名块或者存储过程运行该语句块以及编译存储对象(过程、函数、包、对象类和触发器)时都会确定该对象类型,即使表定义修改,这里也可以一样使用。 
 
   使用%TYPE是一种非常好的编程风格,因为它使得PL/SQL更加灵活,更加适应于对数据库定义的更新。 
 
2. 使用%ROWTYPE 
 
替代: 
PL/SQL记录类型是用户自定义的,记录提供了一种处理独立又作为一个整体单元相关的变量的机制,类似在java开发中定义一个model类。 
 
DECLARE 
 
       /*Define a record type to hold common student informationi*/ 
 
       TYPE t_empRecord IS RECORD( 
 
              var_empId NUMBER(5), 
 
              var_name VARCHAR2(20)); 
       /*Declare a variable of this type.*/ 
 
       v_empInfo t_empRecord; 
 
       用SELECT语句向记录赋值,这将会从数据库中检索数据并将该数据存储到记录中。要注意的是,记录中字段应该和查询结果列表中的字段相匹配。 
 
SELECT emp_id,name 
 
into v_empInfo 
from emp where emp_id=32; 
 
%ROWTYPE 
 
   在PL/SQL中将一个记录声明为具有相同类型的数据库行。PL/SQL提供了%ROWTYPE运算符,使得这样的操作更为方便。 
 
例如: 
 
DECLARE 
       var_emp emp%ROWTYPE; 
 
将定义一个记录,该记录中的字段将与emp表中的列相对应。 
 
游标的一行: 
 
  create or replace procedure PRO_TEMPLATE as 
NEED_DO_FOR_ZL INTEGER; 
CURRENT_MAX_ID MEMO_TEMPLET.TEMPLET_ID%TYPE; 
CURSOR TEMPLATE_CUR IS SELECT TEMPLET_NAME, TEMPLET_CONTENT FROM SYS_TEMPLET; 
TEM_INSTANCE TEMPLATE_CUR%ROWTYPE; 
begin 
null; 
end; 
 

推荐阅读
  • PHP中静态类与静态变量的应用差异探讨
    本文深入探讨了PHP编程语言中静态类与静态变量的具体应用及其差异性,旨在帮助开发者更好地理解和运用这些概念,以提升代码质量和效率。 ... [详细]
  • 如何解决PHP中时间获取不准确的问题
    本文探讨了在PHP开发过程中遇到的时间获取错误问题,并提供了详细的解决方案,包括通过修改配置文件和编程方法来调整时区设置。 ... [详细]
  • 本文旨在探讨机器学习与数据分析之间的差异,不仅在于它们处理的数据类型,还包括技术背景、业务应用场景以及参与者的不同。通过深入分析,希望能为读者提供清晰的理解。 ... [详细]
  • 导入大csv文件到mysql(CSV导入) ... [详细]
  • 当 MySQL 的 autocommit 设置为 1 时,如果在一个事务中执行了 DDL 语句,那么该事务中从开始到执行 DDL 语句之前的所有 DML 操作将自动提交。随后的 DML 操作则需要在新的事务中进行。 ... [详细]
  • 本文档详细介绍了2017年8月31日关于MySQL数据库备份与恢复的教学内容,包括MySQL日志功能、备份策略、备份工具及实战演练。 ... [详细]
  • NIO 通道接口详解
    本文介绍了NIO(New Input/Output)中的通道接口及其相关概念,包括通道的基本功能、接口设计以及各类通道接口的具体用途。通过本文,读者可以深入了解NIO通道的设计原理及其在实际项目中的应用。 ... [详细]
  • 深入探讨PHP中的输出缓冲技术(Output Buffering)
    本文深入解析了PHP中输出缓冲(Output Buffering)的原理及其在Web开发中的应用,特别是如何通过输出缓冲技术有效管理HTTP头部信息,提高代码的灵活性与健壮性。 ... [详细]
  • 本文详细介绍了如何解决Oracle数据库中出现的ORA-28002错误,即密码将在1天内过期的问题,包括原因分析及解决方案。 ... [详细]
  • 本文提供了一套实用的方法论,旨在帮助开发者构建能够应对高并发请求且易于扩展的Web服务。内容涵盖了服务器架构、数据库管理、缓存策略以及异步处理等多个方面。 ... [详细]
  • 作为一名计算机科学专业的大三学生,我在过去的一年里自学了Visual Basic (VB),但感觉进展缓慢。VB的学习是否仅仅局限于控件的使用?如何有效地学习API?此外,有人认为Basic语言已经过时,这对VB的未来意味着什么? ... [详细]
  • 本文探讨了在Python中利用sqlite3库创建或重定义SQLite函数的方法,包括自定义函数和修改现有函数的行为。 ... [详细]
  • 58同城的Elasticsearch应用与平台构建实践
    本文由58同城高级架构师于伯伟分享,由陈树昌编辑整理,内容源自DataFunTalk。文章探讨了Elasticsearch作为分布式搜索和分析引擎的应用,特别是在58同城的实施案例,包括集群优化、典型应用实例及自动化平台建设等方面。 ... [详细]
  • .NET Core中的一个接口多种实现的依赖注入与动态选择看这篇就够了
    .NETCore中的一个接口多种实现的依赖注入与动态选择看这篇就够了最近有个需求就是一个抽象仓储层接口方法需要SqlServer以及Oracle两种实现方式,为了灵活我在依赖注入的 ... [详细]
  • 请求一段SQL代码,用于从数据库中提取当前日期前7天的数据记录。例如,如果今天是2011年5月9日,则需要获取从2011年5月3日至2011年5月9日之间的所有记录。 ... [详细]
author-avatar
diudiu不是狗
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有