SQL Server中游标的使用
2008-12-20 23:30
357 查看
DECLARE @TEMP TABLE
(
Id INT,
LawName NVARCHAR(10),
LogName VARCHAR(10),
countid int
)
DECLARE @Id INT;
DECLARE @LawName VARCHAR(50);
DECLARE @LogName NVARCHAR(10);
DECLARE MYCUR CURSOR FOR
(SELECT Id,LawName,LogName FROM Lawer)--声明游标
OPEN MYCUR--打开游标
FETCH NEXT FROM MYCUR INTO @Id,@LawName,@LogName
WHILE @@FETCH_STATUS = 0--当SQLCODE值为0时表明一切正常,100表示已经取到了结果集的末尾
BEGIN
DECLARE @CNT INT;
SELECT @CNT=count(Id) FROM Lawer WHERE Id=@Id AND LawName=@LawName AND LogName=@LogName
INSERT INTO @TEMP(Id,LawName,LogName,countid) VALUES(@Id,@LawName,@LogName,@CNT)
FETCH NEXT FROM MYCUR INTO @Id,@LawName,@LogName
END
CLOSE MYCUR--关闭游标
DEALLOCATE MYCUR--删除游标资源
SELECT * FROM @TEMP
/*--定位到指定位置的记录
fetch absolute 56488 from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到当前记录相对位置记录
fetch relative -88 from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到当前记录前一条
fetch prior from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到当前记录后一条
fetch next from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到首记录
fetch first from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到尾记录
fetch last from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
*/
(
Id INT,
LawName NVARCHAR(10),
LogName VARCHAR(10),
countid int
)
DECLARE @Id INT;
DECLARE @LawName VARCHAR(50);
DECLARE @LogName NVARCHAR(10);
DECLARE MYCUR CURSOR FOR
(SELECT Id,LawName,LogName FROM Lawer)--声明游标
OPEN MYCUR--打开游标
FETCH NEXT FROM MYCUR INTO @Id,@LawName,@LogName
WHILE @@FETCH_STATUS = 0--当SQLCODE值为0时表明一切正常,100表示已经取到了结果集的末尾
BEGIN
DECLARE @CNT INT;
SELECT @CNT=count(Id) FROM Lawer WHERE Id=@Id AND LawName=@LawName AND LogName=@LogName
INSERT INTO @TEMP(Id,LawName,LogName,countid) VALUES(@Id,@LawName,@LogName,@CNT)
FETCH NEXT FROM MYCUR INTO @Id,@LawName,@LogName
END
CLOSE MYCUR--关闭游标
DEALLOCATE MYCUR--删除游标资源
SELECT * FROM @TEMP
/*--定位到指定位置的记录
fetch absolute 56488 from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到当前记录相对位置记录
fetch relative -88 from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到当前记录前一条
fetch prior from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到当前记录后一条
fetch next from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到首记录
fetch first from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到尾记录
fetch last from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
*/
相关文章推荐
- SQL Server游标的使用
- SQL Server游标语句使用方法:
- SQL Server游标的使用
- Sql Server游标使用 exec函数执行动态sql
- SQL SERVER 游标使用
- 关于sql server动态获取数据库下所有表以及游标的简单使用
- SQL Server游标使用快速上手
- sql server在存储过程中使用游标和事务
- SQL Server的通用分页存储过程 未使用游标,速度更快!
- Sql Server 游标使用 demo
- SQL Server游标的使用
- SQL SERVER游标使用
- SQL Server中的游标使用
- SQL Server游标的使用【转】
- SQL Server游标的使用
- 关于在[SQL Server]Store Procedure中使用OUTPUT 游标
- SQL Server游标的使用【转】
- SQL server 游标,随机数使用
- Sql Server 2000 中游标的使用示例
- SQL Server游标的使用【转】(超详细)