SQL Server遍历表一般都要用到游标,SQL Server中可以很容易的用游标实现循环,实现SQL Server遍历表中记录。本文将介绍利用使用表变量和游标实现网站数据库中表的遍历。简化SQL Server备份与还原到云工作原理及操作办法具体相关方法
除了硬盘和磁带,现在您可以使用 SQL Server 的本机备份功能来备份您的 SQL Server Database到 Windows AzureBlob 存储服务。在此版本中,您可以使用 T-SQ,好处:,· 灵活、 可靠和无限的线下存储来提高灾难恢复: 将您的备份存储在 Windows AzureBlob 服务上是一种方便、 灵活且易于访问线下的选择。创建您的 SQL Server 备份的线下存储就像,· 备份存档: Windows AzureBlob Storage服务提供了更好的一个办法为那些经常使用磁带来存档备份的用户。磁带存储可能需要物理上传输到一个外部设施并且还要保护这些媒体不受破坏。在 ,· 没有硬件管理的开销: 使用Windows Azure存储服务就没有了硬件的管理开销。Windows Azure 服务管理硬件,并为geo-replication保证冗余度和提供针对硬件故障的保护。,· 目前,通过创建附带的磁盘就可以将运行在 WindowsAzure Virtual Machine的 SQL Server 实例备份到 Windows Azure Blob 存储服务上。然而,可以附,· 此外,存储在 Windows AzureBlob 存储服务中的备份网站网站文件可以直接提供给户内 SQL Server或其他运行在 Windows Azure Virtual Machine上的SQL S,· 成本效益: 只需支付所用的服务。是线下备份存档节省成本的一种具体相关方法。Windows Azure pricing calculator可以帮助您估计成本。,存储: 收费会依据您使用的空间,站点服务器的数量和冗余级别而定价。更多详细和最新的信息,请参阅PricingDetails的Data Management 章节。,数据传输:入站数据传输到 Windows Azure是免费的。出站传输根据带宽使用情况,并根据累进特定区域的量而收费。更多详细信息,请参阅条PricingDetails的DataTransfers章节,它是如何工作的:,备份到 Windows Azure Storage设计得像一个备份设备(磁盘/磁带)。使用 MicrosoftVirtual Backup Device Interface (VDI),Windows,当备份或还原过程被调用,并指定 Windows AzureBlob 存储使用 URL"设备类型"时,引擎就会调用VDI 客户端进程,这也是该特征的一部分。备份数据被发送到 VDI 客户端进程,并再被发,如上所述,URL 像咱们现在使用的备份设备一样,但它并不是一个物理设备,所以有一些限制。有关它支持的具体相关方法的全部清单,请参阅SQLServer Backup and Restore with Windo,如何使用它,要写一个Windows AzureBlob 存储的备份,您必须首先创建一个 Windows Azure Storage帐户,再创建一个 SQL Server Credential保存存储帐户的身份验证,下面的 TRANSACT-SQL 示例介绍了创建凭据、 做完整的网站数据库备份和从完整网站数据库备份还原网站数据库的过程。有关创建存储帐户和执行简单还原操作办法的完整的实例,请参见Tutorial:Getting S,创建凭据,下面的示例演示了如何创建一个存储 Windows Azure Storage身份验证信息的凭据。,备份完整的网站数据库,下面的示例演示了如何备份 AdventureWorks2012 网站数据库到 Windows Azure Blob 存储服务上。,还原网站数据库,若要还原完整的网站数据库备份,请按以下步骤操作办法。,
表变量来实现表的遍历
以下具体相关代码中,具体相关代码块之间的差异已经用灰色的背景标记。
复制具体相关代码 具体相关代码如下:
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