//%type
//如果声明的变量是直接映射到数据库的某一列上,那么就可以使用%type关键字将变量
//锚定到这个列上。这样做有什么好处呢?
//比如:
//declare v_ename scott.emp.ename%type;
//当数据类型发生变化时,此方法显得非常灵活。
//如果更改了列的长度,那么锚定到该列上的所有变量都会自动更改其长度;
//假设我们将v_ename定义为varchar2(10),那么当emp表中的ename列发生变化时,
//我们得手动将v_enam更改为emp.ename相同的数据长度;
//当我们使用锚定类型后,变量就会自动进行调整。
//%rowtype
//%rowtype与%type相似;不过它将变量锚定到表的所有列,而不是锚定到某一列;
//更多关于%rowtype与%type,
//请参考:http://blog.csdn.NET/BOBO12082119/archive/2010/12/02/6051367.aspx
//下面是一个实例:
create table dept(
deptno varchar2(5),
dname varchar2(20),
loc varchar2(20)
);
create or replace procedure pro_insert(
deptno_in in dept.deptno%type,
dname_in in dept.dname%type,
loc_in in dept.loc%type
)
as
v_dept dept%rowtype;
begin
begin
insert into dept
select deptno_in,dname_in,loc_in
from dual;
commit;
dbms_output.put_line('inserting successed');
exception
when others then
rollback;
end;
begin
select deptno_in,dname_in,loc_in
into v_dept from dual;
dbms_output.put_line(
'The data having been inserted.'||
'deptno:'||v_dept.deptno||
',dname:'||v_dept.dname||
',loc:'||v_dept.loc
);
end;
end pro_insert;
//
//上面的过程中,使用到了嵌套块;
//所谓嵌套块就是块中包含其他子块;
//嵌套块允许出现在代码块的异常处理部分和执行部分,
//但是不允许出现在声明中。
//
SQL> set serveroutput on;
SQL> exec pro_insert('111','财务部','福州');
inserting successed
The data having been inserted.deptno:111,dname:财务部,loc:福州
PL/SQL procedure successfully completed
//
//从这里看出来,%rowtype定义的变量作用有点相似游标,
//但是我们不能将%rowtype定义的变量当做游标来使用,
//否则我们将会得到下面的错误:
//ORA-01422: exact fetch returns more than requested number of rows
declare v_dept dept%rowtype;
begin
select deptno,dname,loc
into v_dept
from dept;
dbms_output.put_line(
'The data having been inserted.'||
'deptno:'||v_dept.deptno||
',dname:'||v_dept.dname||
',loc:'||v_dept.loc
);
end;
//
//下面我们用游标来实现上面的操作,具体看下面的匿名块:
declare
cursor cv_dept is
select *
from dept;
begin
//变量v_dept不必我们显示声明
//for循环会为我们隐式的打开和关闭游标,不必我们现实的打开和关闭游标
for v_dept in cv_dept loop
dbms_output.put_line(
'deptno:'||v_dept.deptno||
',dname:'||v_dept.dname||
',loc:'||v_dept.loc
);
end loop;
end;
//
deptno:111,dname:财务部,loc:福州
deptno:120,dname:销售部,loc:大连
deptno:130,dname:科研部,loc:北京
PL/SQL procedure successfully completed
  1. //%type
  2. //如果声明的变量是直接映射到数据库的某一列上,那么就可以使用%type关键字将变量
  3. //锚定到这个列上。这样做有什么好处呢?
  4. //比如:
  5. //declare v_ename scott.emp.ename%type;
  6. //当数据类型发生变化时,此方法显得非常灵活。
  7. //如果更改了列的长度,那么锚定到该列上的所有变量都会自动更改其长度;
  8. //假设我们将v_ename定义为varchar2(10),那么当emp表中的ename列发生变化时,
  9. //我们得手动将v_enam更改为emp.ename相同的数据长度;
  10. //当我们使用锚定类型后,变量就会自动进行调整。
  11. //%rowtype
  12. //%rowtype与%type相似;不过它将变量锚定到表的所有列,而不是锚定到某一列;
  13. //更多关于%rowtype与%type,
  14. //请参考:http://blog.csdn.NET/BOBO12082119/archive/2010/12/02/6051367.aspx
  15. //下面是一个实例:
  16. create table dept(
  17. deptno varchar2(5),
  18. dname varchar2(20),
  19. loc varchar2(20)
  20. );
  21. create or replace procedure pro_insert(
  22. deptno_in in dept.deptno%type,
  23. dname_in in dept.dname%type,
  24. loc_in in dept.loc%type
  25. )
  26. as
  27. v_dept dept%rowtype;
  28. begin
  29. begin
  30. insert into dept
  31. select deptno_in,dname_in,loc_in
  32. from dual;
  33. commit;
  34. dbms_output.put_line('inserting successed');
  35. exception
  36. when others then
  37. rollback;
  38. end;
  39. begin
  40. select deptno_in,dname_in,loc_in
  41. into v_dept from dual;
  42. dbms_output.put_line(
  43. 'The data having been inserted.'||
  44. 'deptno:'||v_dept.deptno||
  45. ',dname:'||v_dept.dname||
  46. ',loc:'||v_dept.loc
  47. );
  48. end;
  49. end pro_insert;
  50. //
  51. //上面的过程中,使用到了嵌套块;
  52. //所谓嵌套块就是块中包含其他子块;
  53. //嵌套块允许出现在代码块的异常处理部分和执行部分,
  54. //但是不允许出现在声明中。
  55. //
  56. SQL> set serveroutput on;
  57. SQL> exec pro_insert('111','财务部','福州');
  58. inserting successed
  59. The data having been inserted.deptno:111,dname:财务部,loc:福州
  60. PL/SQL procedure successfully completed
  61. //
  62. //从这里看出来,%rowtype定义的变量作用有点相似游标,
  63. //但是我们不能将%rowtype定义的变量当做游标来使用,
  64. //否则我们将会得到下面的错误:
  65. //ORA-01422: exact fetch returns more than requested number of rows
  66. declare v_dept dept%rowtype;
  67. begin
  68. select deptno,dname,loc
  69. into v_dept
  70. from dept;
  71. dbms_output.put_line(
  72. 'The data having been inserted.'||
  73. 'deptno:'||v_dept.deptno||
  74. ',dname:'||v_dept.dname||
  75. ',loc:'||v_dept.loc
  76. );
  77. end;
  78. //
  79. //下面我们用游标来实现上面的操作,具体看下面的匿名块:
  80. declare
  81. cursor cv_dept is
  82. select *
  83. from dept;
  84. begin
  85. //变量v_dept不必我们显示声明
  86. //for循环会为我们隐式的打开和关闭游标,不必我们现实的打开和关闭游标
  87. for v_dept in cv_dept loop
  88. dbms_output.put_line(
  89. 'deptno:'||v_dept.deptno||
  90. ',dname:'||v_dept.dname||
  91. ',loc:'||v_dept.loc
  92. );
  93. end loop;
  94. end;
  95. //
  96. deptno:111,dname:财务部,loc:福州
  97. deptno:120,dname:销售部,loc:大连
  98. deptno:130,dname:科研部,loc:北京
  99. PL/SQL procedure successfully completed

%RowType 的使用,获取某行的数据类型。

set serveroutput on;
DECLARE
rowData student%ROWTYPE;
BEGIN
SELECT * INTO rowData
FROM student
WHERE sName = 'Jack'; DBMS_OUTPUT.put_line ('find the name: '||rowData.sName);
DBMS_OUTPUT.put_line ('find the age: '||rowData.SAGE);
DBMS_OUTPUT.put_line ('find the email: '||rowData.sEmail);
DBMS_OUTPUT.put_line ('find the phone: '||rowData.sPhone);
DBMS_OUTPUT.put_line ('find the address: '||rowData.sAddress); END;

%type的用法的更多相关文章

  1. Activator.CreateInstance 方法 (Type) 的用法

    转自:http://www.cnblogs.com/lmfeng/archive/2012/01/30/2331666.html Activator.CreateInstance 方法 (Type) ...

  2. 【C#反射】Type的用法

    Type属性的应用 Type type = typeof(MyClass); Console.Write("$类型名:{ type.Name}"); Console.Write(& ...

  3. python type的用法

    目录 描述 语法 用法 type和isinstance Type和Object 描述 python的 type 函数有两个用法,当只有一个参数的时候,返回对象的类型.当有三个参数的时候返回一个类对象. ...

  4. Python中type的用法

    目录 描述 语法 用法 type和isinstance Type和Object 描述 python的 type 函数有两个用法,当只有一个参数的时候,返回对象的类型.当有三个参数的时候返回一个类对象. ...

  5. golang中type常用用法

    golang中,type是非常重要的关键字,一般常见用法就是定义结构,接口等,但是type还有很多其它的用法,在学习中遇到了以下几种,这点简单总结记录下 定义结构 type Person struct ...

  6. Type InvokeMember()用法简介

    举例: Type tDate = typeof(System.DateTime); Object result = tDate.InvokeMember("Now", Bindin ...

  7. linux type命令用法_转

    转自:http://codingstandards.iteye.com/blog/831504 在脚本中type可用于检查命令或函数是否存在,存在返回0,表示成功:不存在返回正值,表示不成功. $ t ...

  8. c# Type.InvokeMember用法

    函数原型: public object InvokeMember(string, BindingFlags, Binder, object, object[]);string:你所要调用的函数名Bin ...

  9. 标准类型内建函数 type()介绍

    我们现在来正式介绍一下 type().在Python2.2 以前, type() 是内建函数.不过从那时起,它变成了一个“工厂函数”.在本章的后面部分我们会讨论工厂函数, 现在你仍然可以将type() ...

随机推荐

  1. JS代码平面化

    重构JS代码 - 让JS代码平面化   js中的嵌套函数用的很多,很牛叉,那为何要平面化? 易懂(自己及他人) 易修改(自己及他人) 平时Ajax调用写法(基于jQuery) $.post('url' ...

  2. 分享一个C#自定义事件的实际应用

    在C#.NET的开发中,事件是经常接触到的概念,比如为按钮添加点击事件,并写入点击按钮触发事件要运行的代码.不管是ASP.NET还是WinForm等各种形式的应用程序,最经常是为系统生成的事件写具体代 ...

  3. 重拾C

    重拾C,一天一点点_10 来博客园今天刚好两年了,两年前开始学编程. 忙碌近两个月,项目昨天上线了,真心不容易,也不敢懈怠,接下来的问题会更多.这两天调试服务器,遇到不少麻烦. 刚出去溜达了一下,晚上 ...

  4. (转)C++重写、重载和重定义的区别

    C++ 重写重载重定义区别 (源自:http://blog.163.com/clevertanglei900@126/blog/static/111352259201102441934870/) 1 ...

  5. Js面向对象编程

    Js面向对象编程 1.     什么是面向对象编程? 我也不说不清楚什么是面向对象,反正就那么回事吧. 编程有时候是一件很快乐的事,写一些小游戏,用编程的方式玩游戏等等 2.     Js如何定义一个 ...

  6. 《12个有趣的C语言问答》评析2

    <12个有趣的C语言问答>评析(2) 前文链接:http://www.cnblogs.com/pmer/p/3313913.html (没存盘,遭遇过热保护.至少4个问答的评论白写了.默哀 ...

  7. C# 根据时间创建文件夹

    string file = ((fileNameIndex)index).ToString(); if (!Directory.Exists(HttpContext.Current.Server.Ma ...

  8. Easyui表单验证扩展

    简介: 使用Easyui,我们省了好多事情,不用为UI费心,只需要关注业务层面即可,下面是一些常用的验证方面的扩展,收藏下自己用 //重载$.fn.validatebox.defaults.rules ...

  9. JDBC之事务隔离级别以及ACID特性

    JDBC之事务隔离级别以及ACID特性 事务隔离级别: 1.更新遗失(Lost update) 两个事务都同时更新一行数据,但是第二个事务却中途失败退出,导致对数据的两个修改都失效了.这是因为系统没有 ...

  10. sqlserver 注释提取工具

    小程序大智慧,sqlserver 注释提取工具 开篇背景 我习惯在写表的创建脚本时将注释直接写在脚本里,比如 ? /*账套*/ CREATE TABLE [dbo].[AccountingBook] ...