%type的用法
//%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
- //%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
%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的用法的更多相关文章
- Activator.CreateInstance 方法 (Type) 的用法
转自:http://www.cnblogs.com/lmfeng/archive/2012/01/30/2331666.html Activator.CreateInstance 方法 (Type) ...
- 【C#反射】Type的用法
Type属性的应用 Type type = typeof(MyClass); Console.Write("$类型名:{ type.Name}"); Console.Write(& ...
- python type的用法
目录 描述 语法 用法 type和isinstance Type和Object 描述 python的 type 函数有两个用法,当只有一个参数的时候,返回对象的类型.当有三个参数的时候返回一个类对象. ...
- Python中type的用法
目录 描述 语法 用法 type和isinstance Type和Object 描述 python的 type 函数有两个用法,当只有一个参数的时候,返回对象的类型.当有三个参数的时候返回一个类对象. ...
- golang中type常用用法
golang中,type是非常重要的关键字,一般常见用法就是定义结构,接口等,但是type还有很多其它的用法,在学习中遇到了以下几种,这点简单总结记录下 定义结构 type Person struct ...
- Type InvokeMember()用法简介
举例: Type tDate = typeof(System.DateTime); Object result = tDate.InvokeMember("Now", Bindin ...
- linux type命令用法_转
转自:http://codingstandards.iteye.com/blog/831504 在脚本中type可用于检查命令或函数是否存在,存在返回0,表示成功:不存在返回正值,表示不成功. $ t ...
- c# Type.InvokeMember用法
函数原型: public object InvokeMember(string, BindingFlags, Binder, object, object[]);string:你所要调用的函数名Bin ...
- 标准类型内建函数 type()介绍
我们现在来正式介绍一下 type().在Python2.2 以前, type() 是内建函数.不过从那时起,它变成了一个“工厂函数”.在本章的后面部分我们会讨论工厂函数, 现在你仍然可以将type() ...
随机推荐
- 话谈c#拷贝
c#中类型分为值类型和引用类型,值类型对象赋值是本身就是赋的自身的一个副本,而引用类型赋值时则赋的是指向堆上的内存,假如我们不想赋这个地址而想将对象赋过去要怎么做呢?首先要知道拷贝分为浅表拷贝和深层拷 ...
- 同源策略与JSONP
[CORS:跨域资源共享] 同源策略与JSONP Web API普遍采用面向资源的REST架构,将浏览器最终执行上下文的JavaScript应用Web API消费者的重要组成部分.“同源策略”限制了J ...
- Scrum与高效能人士的执行4原则
Scrum与高效能人士的执行4原则 分享了高效能人士的执行4原则,发现它和Scrum非常相近,可以形成互补. Scrum框架: 高效能人士的执行4原则框架: Scrum与4原则 Sprint Back ...
- Object-c学习之路八(NSArray(数组)遍历和排序)
今天学习了NSArray的遍历和排序,现在在这里做一下总结: 遍历现在实现了四中方法: 排序大概有三中方法:(代码中都有注释) 关于对象的排序还是以Student和Book为例 每个Student持有 ...
- dmp文件导入的方法
1,使用oracle的imp命令导入*.dmp文件 首先要明确知道,使用oracle的imp命令进行导入,要在一个空的数据库下,才是最好的,否则,数据表存在的话,就要先删除数据表中的数据 步骤1:禁用 ...
- ShardedJedis实现学习
ShardedJedis实现学习-我们到底能走多远系列(33) 我们到底能走多远系列(31) 扯淡: 工作是容易的赚钱是困难的 恋爱是容易的成家是困难的 相爱是容易的相处是困难的 决定是容易的可是等待 ...
- T-SQL查询语句(二):嵌套查询
一个select...From...Where查询语句块可以嵌套在另一个select...From...Where查询块的Where子句中,称为嵌套查询.外层查询称为父查询,主查询.内层查询称为子查询 ...
- ORM查询语言(OQL)简介高级篇
ORM查询语言(OQL)简介--高级篇:脱胎换骨 在写本文之前,一直在想文章的标题应怎么取.在写了<ORM查询语言(OQL)简介--概念篇>.<ORM查询语言(OQL)简介--实例篇 ...
- JSP实现页面跳转的方式
js实现页面跳转的几种方式普通方式 第一种: <script language="javascript" type="text/javascript"&g ...
- hdu 1213 How Many Tables(并查集练习)
题目链接:hdu1213 赤裸裸的并查集.....水题一个.... #include<stdio.h> #include<string.h> #include<algor ...