❶ 存储过程中输出参数为游标的时候怎么处理
最好别用游标做输出参数,你可以先用一个临时变量做游标,最后赋值给输出参数
❷ 请问,我如果需要把一个游标的当前指针,作为传入参数从一个存储过程传给另一存储过程,要如何处理。最好
设置一个全局的指针,将游标地址赋给指针,就可以用指针当做参数多次传递了
❸ mysql存储过程中使用游标的实例
复制代码
代码如下:
DELIMITER
$$
DROP
PROCEDURE
IF
EXISTS
getUserInfo
$$
CREATE
PROCEDURE
getUserInfo(in
date_day
datetime)
--
--
实例
--
MYSQL存储过程名为:getUserInfo
--
参数为:date_day日期格式:2008-03-08
--
BEGIN
declare
_userName
varchar(12);
--
用户名
declare
_chinese
int
;
--
语文
declare
_math
int
;
--
数学
declare
done
int;
--
定义游标
DECLARE
rs_cursor
CURSOR
FOR
SELECT
username,chinese,math
from
userInfo
where
datediff(createDate,
date_day)=0;
DECLARE
CONTINUE
HANDLER
FOR
NOT
FOUND
SET
done=1;
--
获取昨天的日期
if
date_day
is
null
then
set
date_day
=
date_add(now(),interval
-1
day);
end
if;
open
rs_cursor;
cursor_loop:loop
FETCH
rs_cursor
into
_userName,
_chinese,
_math;
--
取数据
if
done=1
then
leave
cursor_loop;
end
if;
--
更新表
update
infoSum
set
total=_chinese+_math
where
UserName=_userName;
end
loop
cursor_loop;
close
rs_cursor;
END$$
DELIMITER
;
❹ oracle中有一存储过程,其中包含了游标。java中我要调用这个存储过程,传值时是否需要对游标传值,还是自
不能对游标传值,游标不能作为存储过程的入参。但是可以为游标的定义传值。这个值作为定义游标的where条件的参数值。
❺ 如何在存储过程中使用游标
ALTER proc [dbo].[存储过程名]
as
begin
declare 游标名字 cursor for select 列名 from 表名 where 条件--先申明游标指向查询出的结果,一列,或者多列都可以,条件自定
declare 变量名 varchar(400)--存储取到的值
open 游标名 --开启游标
while @@FETCH_STATUS=0--取值
begin
fetch next FROM 游标名 into 变量名--这样就将游标指向下一行,得到的第一行值就传给变量了
-------------------------------------------
--需要执行的操作,例如修改某表中的字段
update 表名
set 列名=值
where (修改表中的列)=变量名
-------------------------------------------
end
close 游标名--关闭游标
deallocate 游标名--释放游标
end
❻ java调用的存储过程,能否传入游标参数
调用存储过程是可以传数组的,首先oracle编写的存储过程是需要带有数组参数的
参考资料给出例子很典型。
❼ 存储过程使用游标
ALTER proc [dbo].[存储过程名]
as
begin
declare 游标名字 cursor for select 列名 from 表名 where 条件--先申明游标指向查询出的结果,一列,或者多列都可以,条件自定
declare 变量名 varchar(400)--存储取到的值
open 游标名 --开启游标
while @@FETCH_STATUS=0--取值
begin
fetch next FROM 游标名 into 变量名--这样就将游标指向下一行,得到的第一行值就传给变量了
-------------------------------------------
--需要执行的操作,例如修改某表中的字段
update 表名
set 列名=值
where (修改表中的列)=变量名
-------------------------------------------
end
close 游标名--关闭游标
deallocate 游标名--释放游标
end
请采纳。
❽ oracle存储过程的参数游标应该怎样来赋值
oracle存储过程的参数游标应该怎样来赋值
可以使用动态游标。
REF CURSOR 存储过程中使用 open cursor xxx for select xxx ;
❾ 存储过程中游标是怎么用的
CREATE PROCEDURE sp_BuildIndexes
AS
DECLARE @TableName sysname,@msg varchar(100),@cmd varchar(100)
DECLARE table_cur CURSOR FOR
SELECT name FROM sysobjects WHERE TYPE='U' --在sysobjects表中'u'表示用户创建的表
OPEN table_cur
FETCH NEXT FROM table_cur INTO @TableName
WHILE @@fetch_status=0
BEGIN
IF @@fetch_status=-2
CONTINUE
SELECT @msg='Building indexes for table'+@TableName+'_'
PRINT @msg
SELECT @cmd='DBCC DBREINDEX('+@TableName+')'
EXEC (@cmd)
PRINT ''
FETCH NEXT FROM table_cur INTO @TableName
END
DEALLOCATE table_cur
GO
EXEC sp_BuildIndexes
EXEC('DBCC DBREINDEX(authors)') --许多 DBCC 语句能够对检测到的问题进行修复。
--重建索引(dbcc dbreindex)
❿ 存储过程为什么要用游标,什么情况下使用游标
游标一般用于把通过脚本得到的结果集的内容在用于其它的SQL语句中。但是游标执行会影响脚本执行速度,所以使用时请慎重。 在存储过程或触发器中使用 SQL 游标的典型过程为: 声明SQL 变量包含游标返回的数据。为每个结果集列声明一个变量。声明足够大的变量来保存列返回的值,并声明变量的类型为可从列数据类型隐式转换得到的数据类型。
使用 DECLARE CURSOR 语句将 SQL 游标与 SELECT 语句相关联。另外,DECLARE CURSOR 语句还定义游标的特性,例如游标名称以及游标是只读还是只进。
使用 OPEN 语句执行 SELECT 语句并填充游标。
使用 FETCH INTO 语句提取单个行,并将每列中的数据移至指定的变量中。然后,其他 SQL 语句可以引用那些变量来访问提取的数据值。SQL 游标不支持提取行块。
使用 CLOSE 语句结束游标的使用。关闭游标可以释放某些资源,例如游标结果集及其对当前行的锁定,但如果重新发出一个 OPEN 语句,则该游标结构仍可用于处理。由于游标仍然存在,此时还不能重新使用该游标的名称。DEALLOCATE 语句则完全释放分配给游标的资源,包括游标名称。释放游标后,必须使用 DECLARE 语句来重新生成游标。
请采纳。