oracle游标问题
cursor有隐式和显式之分,但我有点不太清楚,比方在程序里调用一句sql,比方最简单的select*fromtableName;进行整表查询,这时候sql真正在orac...
cursor有隐式和显式之分,但我有点不太清楚,比方在程序里调用一句sql,比方最简单的select * from tableName;进行整表查询,这时候sql真正在oracle解析的时候会隐式的使用游标来解析么
显式的游标是不是就是存储过程定义的cursor呢 展开
显式的游标是不是就是存储过程定义的cursor呢 展开
3个回答
展开全部
显式游标使用的是SELECT叙述,被声明于任何一个区块的声明段落中,开发者可以控制几乎所有与游标有关的操作。
显示游标对游标的处理提供了其他类似的游标无法做到的控制。他们要使用一次会传回多余一笔记录的SELECT叙述。
虽然他们提供了比隐式游标更多的控制,但也需要额外的步骤来操作。
PL/SQL为所有SQL数据操作语句(包括返回一行的SELECT)隐式声明游标,称为隐式声明游标的原因是用户不能直接命名和控制此类游标。当用户在PL/SQL中使用数据库操作语言(DML)时,Oracle预定义一个名为SQL的隐式游标,通过检查隐式游标的属性可以获取与最近执行的SQL语句相关的信息。
CURSOR mycur is select * from DUAL
后面通过打开游标(open cursor),获取数据(fetch ...into),关闭游标(close cursor)来控制.
这种方式就是显示游标
for i in(select * from DUAL) loop ...end loop
这种就是隐式游标
显示游标对游标的处理提供了其他类似的游标无法做到的控制。他们要使用一次会传回多余一笔记录的SELECT叙述。
虽然他们提供了比隐式游标更多的控制,但也需要额外的步骤来操作。
PL/SQL为所有SQL数据操作语句(包括返回一行的SELECT)隐式声明游标,称为隐式声明游标的原因是用户不能直接命名和控制此类游标。当用户在PL/SQL中使用数据库操作语言(DML)时,Oracle预定义一个名为SQL的隐式游标,通过检查隐式游标的属性可以获取与最近执行的SQL语句相关的信息。
CURSOR mycur is select * from DUAL
后面通过打开游标(open cursor),获取数据(fetch ...into),关闭游标(close cursor)来控制.
这种方式就是显示游标
for i in(select * from DUAL) loop ...end loop
这种就是隐式游标
展开全部
隐式游标 是具有特殊性质的select 语句: 代码块执行单元的select语句(显示游标在声明单元定义);查询带有into 语句(或者批量的bulk collect into);不用打开、提取、关闭,数据库自动完成。
显示游标 是代码声明单元明确定义的select语句,并同时制定一个名字,语法是:
CURSOR cursor_name [parameter][RETURN return_specification]
IS SELECT_statement;
声明了游标后,就可以打开游标(open cursor),获取数据(fetch ...into),关闭游标(close cursor)。
还有一种游标变量 (ref cursor),语法:
type cursor_name is ref cursor [return return_type];
打开用 open ... for...
显示游标 是代码声明单元明确定义的select语句,并同时制定一个名字,语法是:
CURSOR cursor_name [parameter][RETURN return_specification]
IS SELECT_statement;
声明了游标后,就可以打开游标(open cursor),获取数据(fetch ...into),关闭游标(close cursor)。
还有一种游标变量 (ref cursor),语法:
type cursor_name is ref cursor [return return_type];
打开用 open ... for...
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询