≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 数据库 > SQL Server

SQL Server遍历表中记录的2种方法(使用表变量和游标)

人气:456 时间:2020-04-16

这篇文章主要为大家详细介绍了SQL Server遍历表中记录的2种方法(使用表变量和游标),具有一定的参考价值,可以用来参考一下。

感兴趣的小伙伴,下面一起跟随四海网的小编两巴掌来看看吧!

SQL Server遍历表一般都要用到游标,SQL Server中可以很容易的用游标实现循环,实现SQL Server遍历表中记录。本文将介绍利用使用表变量和游标实现数据库中表的遍历。

表变量来实现表的遍历
以下代码中,代码块之间的差异已经用灰色的背景标记。

代码如下:

 
DECLARE @temp TABLE 
( 
[id] INT IDENTITY(1, 1) , 
[Name] VARCHAR(10) 
) 
DECLARE @tempId INT , 
@tempName VARCHAR(10) 
INSERT INTO @temp 
VALUES ( 'a' ) 
INSERT INTO @temp 
VALUES ( 'b' ) 
INSERT INTO @temp 
VALUES ( 'c' ) 
INSERT INTO @temp 
VALUES ( 'd' ) 
INSERT INTO @temp 
VALUES ( 'e' ) 
WHILE EXISTS ( SELECT [id] 
FROM @temp ) 
BEGIN 
SET ROWCOUNT 1 
SELECT @tempId = [id] , 
@tempName = [Name] 
FROM @temp 
SET ROWCOUNT 0 
--delete from @temp where [id] = @tempId 
PRINT 'Name:----' + @tempName 
END 

但是这种方法,必须借助ROWCOUNT。但是使用 SET ROWCOUNT 将可能会影响 DELETE、INSERT 和 UPDATE 语句。
所以修改上面WHILE循环,改用TOP来选出首条记录。

代码如下:

 
WHILE EXISTS ( SELECT [id] 
FROM @temp ) 
BEGIN 
SELECT TOP 1 
@tempId = [id] , 
@tempName = [Name] 
FROM @temp 
DELETE FROM @temp 
WHERE [id] = @tempId 
SELECT * 
FROM @temp 
EXEC('drop table '+) 
PRINT 'Name:----' + @tempName 
END 

这种方法也存在一个问题,需要将遍历过的行删除,事实上,我们在实际应用中可能并不想要遍历完一行就删除一行。
利用游标来遍历表
  游标是非常邪恶的一种存在,使用游标经常会比使用面向集合的方法慢2-3倍,当游标定义在大数据量时,这个比例还会增加。如果可能,尽量使用while,子查询,临时表,函数,表变量等来替代游标,记住,游标永远只是你最后无奈之下的选择,而不是首选。

代码如下:

 
--定义表变量 
DECLARE @temp TABLE 
( 
[id] INT IDENTITY(1, 1) , 
[Name] VARCHAR(10) 
) 
DECLARE @tempId INT , 
@tempName VARCHAR(10) 
DECLARE test_Cursor CURSOR LOCAL FOR 
SELECT [id],[name] FROM @temp 
--插入数据值 
INSERT INTO @temp 
VALUES ( 'a' ) 
INSERT INTO @temp 
VALUES ( 'b' ) 
INSERT INTO @temp 
VALUES ( 'c' ) 
INSERT INTO @temp 
VALUES ( 'd' ) 
INSERT INTO @temp 
VALUES ( 'e' ) 
--打开游标 
OPEN test_Cursor 
WHILE @@FETCH_STATUS = 0 
BEGIN 
FETCH NEXT FROM test_Cursor INTO @tempId,@tempname 
PRINT 'Name:----' + @tempName 
END 
CLOSE test_Cursor 
DEALLOCATE test_Cursor 

本文来自:http://www.q1010.com/179/8560-0.html

注:关于SQL Server遍历表中记录的2种方法(使用表变量和游标)的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:SQL SERVER

您可能感兴趣的文章

  • oracle,mysql,SqlServer三种数据库的分页查询的实例
  • SQLSERVER的排序问题结果不是想要的
  • SqlServer 扩展属性的介绍
  • 真正高效的SQLSERVER分页查询(多种方案)
  • sqlserver (parse name)字符串截取的方法
  • sqlserver数据库出现置疑的解决思路
  • sqlserver中delete、update中使用表别名和oracle的区别
  • SqlServer获取存储过程返回值的实例
  • sqlserver附加.mdf权限问题解决
  • 高效的SQLSERVER分页查询(推荐)
上一篇:SqlServer数据库全角转换成半角
下一篇:SQL Server利用bcp命令把SQL语句结果生成文本文件
热门文章
  • SQL Server SQL获取第一条记录的方法
  • SQL Server出现System.OutOfMemoryException异常的解决方法
  • SQL Server的 update from 语句的简单示例
  • SQL Server 数据库备份方法菜鸟教程
  • SQL Server 多表关联时在where语句中慎用trim()方法
  • SQL Server数据类型及长度限制详细说明
  • mybaits非配置原因,导致SqlSession was not registered for synchronization异常解析
  • SQL Server 收缩后对数据库的使用有影响吗?
  • SQL Server 格式导致的Excel导入sql出现异常的解决方法
  • SQL Server 连接服务器出现错误 7391的解决方法
  • 最新文章
    • SQL Server存储过程基本语法的简单示例
    • sql查询时增加自动编号和分页的简单示例
    • sql轻松应付百万数据的高效数据分页存储过程的简单示例
    • sql获取一条数据中所有字段的名称和值的实现方法
    • sql分割函数的简单示例
    • SQL Server异常捕获的简单示例
    • SQL SERVER回滚恢复误操作数据的实现方法
    • SQL Server函数或存储过程中抛出异常的实现方法
    • SQL Server创建数据库的完整代码
    • SQL Server创建数据库的命令用法示例

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。