sqlserver临时表或表变量代替游标

在很多场合,用临时表或表变量也可以替代游标

临时表用在表没有标识列(int)的情况下.

在表有标识列(int)的情况下可以用表变量,当然也可以用临时表.

利用临时表或表变量的原因时,生成一个连续的列
对于临时表是使用
SELECT .... ,IDENTITY(int) NewID INTO #tmp SELECT ... FROM YourTable

对于YourTable含有标识列(比如字段名为ID)时,可以
INSERT @tmpTable
SELECT ..., NewID=(SELECT COUNT(*) FROM YourTable b WHERE b.id<=a.id) FROM YourTable a

当然,也可以不写入表变量而使用子查询.

当有了从 1--你的记录数连续的NewID时, 你就可以用循环来操作每一条记录了.
这个NewID你就可以当它是指针标识.
DECLARE @i INT,@cnt INT
SET @i=1
SELECT @cnt=COUNT(*) FROM YourTable
WHILE @i<@cnt
     BEGIN
           SELECT
.... FROM #tmp(或@tmpTable依上面情况不同) WHERE [email protected]
           ...
           SET
@[email protected]+1
     END

DROP TABLE...

---------

存储过程的循环和临时表

代码举例:

CREATE PROCEDURE get_zb_count_3

@J_JID varchar(50), 
@S_Area varchar(6000), 
@K_ID varchar(50), 
@zb_count int output

AS 
begin 
declare @i int ---存放循环变量 
declare @count int ---存放表的数据记录数

declare @Kh_ID varchar(50)-----存放考核子指标值 
declare @total int ------存放count的循环累计

create table #KhStyle(IntID int identity(1,1), StyleID varchar(50)) ---创建临时表

insert into #KhStyle(StyleID) select K_ID from T_Kaoh where [email protected]_JID and [email protected]_ID --------把查询的子指标记录插入到临时表

select @count = count(1) from #KhStyle ---查询当前临时表的子指标记录

if (@count>0) 
-------------------------------------------------1---------------------------------- 
begin 
set @i = 1 -------变量初始化

set @total = 0 ---累计初始化

while (@i <= @count) -------开始循环 
--------------------------------------------2-------------------------- 
begin 
select @Kh_ID = StyleID from #KhStyle where intID = @i --循环把临时表的子指标值 给于变量 @Kh_ID

select @zb_count=count(*) from v_kh_jg where [email protected]_JID and [email protected]_ID and S_Area in (select *
from GetTB(@S_Area)) -----当前子指标所属企业数

if @zb_count = 0 
select @zb_count = 1 ---如果没有企业则为1

select @total= @zb_count [email protected] ---累计

select @i = @i +1 --循环递增 
end 
-------------------------------------------2---------------------------

set @[email protected] 
end 
---------------------------------------------1--------------------------------- 
else

set @zb_count=0

drop table #KhStyle---删除临时表 
end 
GO 

说明:我这里用到了临时表的功能,通过这个存储过程至少能学到三点知识

1、变量是如何定义的
以下为程序代码:


declare @intID int 
declare @varname varchar(100) 

2、临时表的使用

以下为程序代码:


Create Table #StyleTab(intID int identity(1,1),StyleID varchar(50))----创建临时表

请注意格式:#表名(字段名称 类型,字段名称 类型)

比较有用的一个字段就是自动增长的标识性字段的定义 intID int identity(1,1)

Drop Table #StyleTab----删除临时表 

3、循环的用法

以下为程序代码:

一般i通常作为变量 
while(i<=5) 
begin 
-----代码 
end

时间: 2024-11-08 15:10:06

sqlserver临时表或表变量代替游标的相关文章

SqlServer——临时表和表变量

一.临时表概述 SqlServer临时表有两种:局部临时表.全局临时表. 1.临时表的共同特点: 无论会话的数据库上下文如何,临时表都被保存到 tempdb 数据库中: 当临时表数据较少时,页被保存到内存中:内存不足时,才持久化临时表的页: 判断临时表是否存在:if object_id('tempdb..#临时表名','U') N) is not null print '存在'; 2.临时表之间的区别 局部临时表: 临时表名前以#开头,临时表由创建该表的会话所有,为实现不同会话之间同名的临时表相

SQL 临时表或表变量替代游标

1.如果表没有自动增长的标识列(int) 使用临时表 SELECT IDENTITY(int) NewID ,.. INTO #tmp FROM YouTable 2.表有标识列 使用表变量 INSERT INTO @tmpTable SELECT ..., NewID=(SELECT COUNT(*) FROM YouTable b WHERE b.aid<=a.aid) FROM YouTable a 当有了从 1到~d 的连续NewID时, 你就可以用循环来操作每一条记录了.这个NewID

SQLServer中临时表与表变量的区别分析

在实际使用的时候,我们如何灵活的在存储过程中运用它们,虽然它们实现的功能基本上是一样的,可如何在一个存储过程中有时候去使用临时表而不使用表变量,有时候去使用表变量而不使用临时表呢? 临时表 临时表与永久表相似,只是它的创建是在Tempdb中,它只有在一个数据库连接结束后或者由SQL命令DROP掉,才会消失,否则就会一直存在.临时表在创建的时候都会产生SQL Server的系统日志,虽它们在Tempdb中体现,是分配在内存中的,它们也支持物理的磁盘,但用户在指定的磁盘里看不到文件. 临时表分为本地

临时表VS表变量--因地制宜,合理使用

一直以来大家对临时表与表变量的孰优孰劣争论颇多,一些技术群里的朋友甚至认为表变量几乎一无是处,比如无统计信息,不支持事务等等.但事实并非如此.这里我就临时表与表变量做个对比,对于大多数人不理解或是有歧义的地方进行详细说明. 注:这里只讨论一般临时表,对全局临时表不做阐述. 生命周期 临时表:会话中,proc中,或使用显式drop 表变量:batch中 这里用简单的code说明表变量作用域 DECLARE @t TABLE(i int) ----定义表变量@t SELECT *FROM @t --

InMemory:在内存中创建临时表和表变量

在Disk-Base数据库中,如果系统频繁地创建和更新临时表,大量的IO操作集中在tempdb中,tempdb很可能成为系统性能的瓶颈.在SQL Server 2016的内存(Memory-Optimized)数据库中,如果考虑使用内存优化结构来存储临时表,表变量,表值参数的数据,那么将完全消除IO操作的负载消耗,发挥大内存的优势,大幅提高数据库的性能. 在SQL Server 2016中,能够直接创建内存优化的表类型,表变量和表值参数的数据只存储在内存中:不能直接在内存中创建临时表,但是,SQ

SQL使用临时表,表变量,公式表表达式

当我们使用嵌套查询时,有时候希望把一个查询到的数据先保存在一个临时表里供其他查询使用,这时候就会考虑使用临时表,表变量,或公式表表达式 1. 公式表表达式, SQL中使用WITH AS提高性能-使用公用表表达式(CTE)简化嵌套SQL  , 1) WITH AS的含义 WITH AS短语,也叫做子查询部分(subquery factoring),可以让你做很多事情,定义一个SQL片断,该SQL片断会被整个SQL语句所用到.有的时候,是为了让SQL语句的可读性更高些,也有可能是在UNION ALL

存储过程中引用的常规表,临时表以及表变量是否会导致存储过程的重编译

在存储过程中,经常要引用一些表来存储一些中间数据,用完即删.对于这个中间表,用常规表,临时表或者表变量有什么区别呢? 下面我们看一下这三种中间表是否会造成执行计划的重编译. 首先打开sql server profile,监控存储过程. 1.建第一个存储过程,在存储过程中创建常规表TT1 CREATE PROCEDURE TEST1_PRO AS BEGIN CREATE TABLE TT1( ID INT IDENTITY, NAME VARCHAR(10) ) INSERT INTO TT1

SQL Server中临时表与表变量的区别

2009年02月20日 星期五  19:31 我 们在数据库中使用表的时候,经常会遇到两种使用表的方法,分别就是使用临时表及表变量.在实际使用的时候,我们如何灵活的在存储过程中运用它们,虽然它们 实现的功能基本上是一样的,可如何在一个存储过程中有时候去使用临时表而不使用表变量,有时候去使用表变量而不使用临时表呢? 临时表 临时表与永久表相似,只是它的创建是在Tempdb中,它只有在一个数据库连接结束后或者由SQL命令DROP掉,才会消失,否则就会一直存在.临时表在创建的时候都会产生SQL Ser

SQL Server中的临时表和表变量 Declare @Tablename Table

在SQL Server的性能调优中,有一个不可比面的问题:那就是如何在一段需要长时间的代码或被频繁调用的代码中处理临时数据集?表变量和临时表是两种选择.记得在给一家国内首屈一指的海运公司作SQL Server应用性能评估和调优的时候就看到过大量的临时数据集处理需求,而他们的开发人员就无法确定什么时候用临时表,什么时候用表变量,因此他们就简单的使用了临时表.实际上临时表和表变量都有特定的适用环境.先卖弄一些基础的知识:表变量变量都以@或@@为前缀,表变量是变量的一种,另外一种变量被称为标量(可以理