sql server 创建临时表、循环

 

需求:求表中某一字段中不同数据,在这个表中的数量
优点:减轻了 sql 语句 行转列,列转行的 繁琐 
方法:

  1. 先创建新的存储过程,声明变量和函数名
  2. 创建临时表,声明局部变量名   
  3. 声明游标、打开游标、提取结果带入游标
  4. 对游标内容进行修饰,将修饰内容代入游标,关闭游标,解除游标参照
           
USE [crm_zibogd]
GO

/****** Object:  StoredProcedure [dbo].[CSPD]    Script Date: 2018/11/24 9:17:38 ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

-- =============================================
-- Author:		<Author,,吴炳信>
-- Create date: <Create Date,,>
-- Description:	<Description,,派单工单统计>
-- =============================================
ALTER PROCEDURE [dbo].[CSPD]
	-- Add the parameters for the stored procedure here
	@szStart varchar(32),      ---开始时间
	@szEnd   varchar(32)       ---结束时间
AS
BEGIN
	-- SET NOCOUNT ON added to prevent extra result sets from
	-- interfering with SELECT statements.
	SET NOCOUNT ON;

	DECLARE @SQL NVARCHAR(MAX)			--declare 声明局部变量
	DECLARE @CMD VARCHAR(2048)
	DECLARE @where VARCHAR(2048)
	
	DECLARE @TypeName   INT
    DECLARE @SL   INT
	DECLARE @ALL  INT
	
	 
	CREATE TABLE #TmpOrder --创建临时表#Tmp
     (
		ID        INT IDENTITY (1,1)  not null, --创建列ID,并且每次新增一条记录就会加1
        DQ_1  int,
        DQ_2  INT,
		DQ_3  INT,
		DQ_4  INT,
		DQ_5  INT,
		DQ_6  INT,
		DQ_7  INT,
		DQ_8  INT,
		DQ_9  INT,
		DQ_10  INT,
		DQ_12  INT,
		GSDQ  nvarchar(100),	
     );

	---维修派单工单统计
	---OrderType 维修-数字电视、宽带 报修  ,Brand 数字电视、宽带
	---Admissibility 客服中心
	---ComId  分公司
	---state (0-未处理,1-已预约,2-以结束,3-已退单,4-已追回)

	 INSERT INTO #TmpOrder (GSDQ) VALUES ('客服中心维修派单数')
	 INSERT INTO #TmpOrder (GSDQ) VALUES ('分公司自派维修派单数')
	 INSERT INTO #TmpOrder (GSDQ) VALUES ('客户经理人数') 
	 INSERT INTO #TmpOrder (GSDQ) VALUES ('数字电视报修数量')
	 

		 -- 声明游标 3
    DECLARE RPT_Type CURSOR FOR Select Id From Sys_Company WHERE stat=0 ORDER BY ID    --RPT_Type = Sys_Company 表中的ID
	--打开游标
	OPEN RPT_Type
	--将提取结果带入游标
	FETCH NEXT FROM RPT_Type INTO @TypeName

	WHILE @@FETCH_STATUS = 0

	BEGIN
	--对游标内容进行修饰		
								
								
		SET @sql='SELECT @SL=COUNT(ComId) 
		FROM Mobile_WorkOrder_131130 with(nolock) WHERE ComId = '+cast(@TypeName as nvarchar)+' 
		and  left (Admissibility ,4) = ''客服中心''
		and  addtime between '''+@szStart+''' and  '''+@szEnd+'''' 
		PRINT @sql
		exec  sp_executesql @sql,N'@SL int output',@SL output
		
		SET @sql='UPDATE #TmpOrder SET DQ_'+cast(@TypeName as nvarchar)+' = '+cast(@SL as nvarchar)+ ' where GSDQ =''客服中心维修派单数''' 
				--DQ_'+cast(@TypeName as nvarchar) = DQ_"ID"  | cast(@SL as nvarchar) = COUNT(Id)
		PRINT @sql
		exec  (@sql)

	--将修饰内容代入游标	
	FETCH NEXT FROM RPT_Type INTO  @TypeName
	END
	-- 关闭游标
	CLOSE RPT_Type
	--解除游标参照
	DEALLOCATE RPT_Type


		 -- 声明游标 4
    DECLARE RPT_Type CURSOR FOR Select Id From Sys_Company WHERE stat=0 ORDER BY ID    --RPT_Type = Sys_Company 表中的ID
	--打开游标
	OPEN RPT_Type
	--将提取结果带入游标
	FETCH NEXT FROM RPT_Type INTO @TypeName

	WHILE @@FETCH_STATUS = 0

	BEGIN
	--对游标内容进行修饰		
								
								
		SET @sql='SELECT @SL=COUNT(ComId) 
		FROM Mobile_WorkOrder_131130 with(nolock) WHERE ComId = '+cast(@TypeName as nvarchar)+' 
		and left (WorkId,3)=''601''
		and  addtime between '''+@szStart+''' and  '''+@szEnd+'''' 
		PRINT @sql
		exec  sp_executesql @sql,N'@SL int output',@SL output
		
		SET @sql='UPDATE #TmpOrder SET DQ_'+cast(@TypeName as nvarchar)+' = '+cast(@SL as nvarchar)+ ' where GSDQ =''分公司自派维修派单数''' 
				--DQ_'+cast(@TypeName as nvarchar) = DQ_"ID"  | cast(@SL as nvarchar) = COUNT(Id)
		PRINT @sql
		exec  (@sql)

	--将修饰内容代入游标	
	FETCH NEXT FROM RPT_Type INTO  @TypeName
	END
	-- 关闭游标
	CLOSE RPT_Type
	--解除游标参照
	DEALLOCATE RPT_Type


		 -- 声明游标  5
    DECLARE RPT_Type CURSOR FOR Select Id From Sys_Company WHERE stat=0 ORDER BY ID    --RPT_Type = Sys_Company 表中的ID
	--打开游标
	OPEN RPT_Type
	--将提取结果带入游标
	FETCH NEXT FROM RPT_Type INTO @TypeName

	WHILE @@FETCH_STATUS = 0

	BEGIN
	--对游标内容进行修饰		
								
		SET @sql='SELECT @SL=COUNT(ComId) 
		FROM Mobile_Users with(nolock) WHERE ComId = '+cast(@TypeName as nvarchar)+' 
		and AgentRole=4 and AgentStat=1
		' 
		PRINT @sql
		exec  sp_executesql @sql,N'@SL int output',@SL output
		
		SET @sql='UPDATE #TmpOrder SET DQ_'+cast(@TypeName as nvarchar)+' = '+cast(@SL as nvarchar)+ ' where GSDQ =''客户经理人数''' 
				--DQ_'+cast(@TypeName as nvarchar) = DQ_"ID"  | cast(@SL as nvarchar) = COUNT(Id)
		PRINT @sql
		exec  (@sql)

	--将修饰内容代入游标	
	FETCH NEXT FROM RPT_Type INTO  @TypeName
	END
	-- 关闭游标
	CLOSE RPT_Type
	--解除游标参照
	DEALLOCATE RPT_Type


		 -- 声明游标  6
    DECLARE RPT_Type CURSOR FOR Select Id From Sys_Company WHERE stat=0 ORDER BY ID    --RPT_Type = Sys_Company 表中的ID
	--打开游标
	OPEN RPT_Type
	--将提取结果带入游标
	FETCH NEXT FROM RPT_Type INTO @TypeName

	WHILE @@FETCH_STATUS = 0

	BEGIN
	--对游标内容进行修饰		
								
		SET @sql='SELECT @SL=COUNT(ComId) 
		FROM Mobile_WorkOrder_131130 with(nolock) WHERE ComId = '+cast(@TypeName as nvarchar)+' 
		and left (Brand,4)= ''数字电视''	
		and  addtime between '''+@szStart+''' and  '''+@szEnd+'''' 
		PRINT @sql
		exec  sp_executesql @sql,N'@SL int output',@SL output
		
		SET @sql='UPDATE #TmpOrder SET DQ_'+cast(@TypeName as nvarchar)+' = '+cast(@SL as nvarchar)+ ' where GSDQ =''数字电视报修数量''' 
				--DQ_'+cast(@TypeName as nvarchar) = DQ_"ID"  | cast(@SL as nvarchar) = COUNT(Id)
		PRINT @sql
		exec  (@sql)

	--将修饰内容代入游标	
	FETCH NEXT FROM RPT_Type INTO  @TypeName
	END
	-- 关闭游标
	CLOSE RPT_Type
	--解除游标参照
	DEALLOCATE RPT_Type

    -- Insert statements for procedure here
	SELECT * From #TmpOrder
END

GO


查询 是否正确: exec [dbo].[CSPD] ‘时间段’,‘时间段’

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL Server中,可以使用游标(cursor)来遍历临时。 首先,我们需要创建一个临时,并向其插入数据。可以使用以下语句来创建和插入数据: ```sql CREATE TABLE #TempTable ( ID INT, Name VARCHAR(50) ) INSERT INTO #TempTable(ID, Name) VALUES (1, 'John'), (2, 'Mike'), (3, 'Sarah') ``` 接下来,可以使用游标来遍历临时。游标是一个类似指针的数据结构,可以逐行访问结果集。 ```sql DECLARE @ID INT DECLARE @Name VARCHAR(50) DECLARE TempCursor CURSOR FOR SELECT ID, Name FROM #TempTable OPEN TempCursor FETCH NEXT FROM TempCursor INTO @ID, @Name WHILE @@FETCH_STATUS = 0 BEGIN -- 在这里可以对每一行数据进行处理 PRINT 'ID: ' + CONVERT(VARCHAR(10), @ID) + ', Name: ' + @Name FETCH NEXT FROM TempCursor INTO @ID, @Name END CLOSE TempCursor DEALLOCATE TempCursor ``` 上述代码中,我们声明了两个变量`@ID`和`@Name`来存储临时中的ID和Name列的值。然后,声明了一个游标`TempCursor`,并将临时中的数据集合赋给游标。接着,我们打开游标,并使用`FETCH NEXT`语句将第一行数据读取到变量中。 在while循环中,我们可以对每一行数据进行处理。在这里,我们使用`PRINT`语句将ID和Name的值打印出来,你可以在这里进行其他的处理操作。 最后,我们关闭游标并释放它所占用的资源。 需要注意的是,在使用游标遍历临时时,一定要记得关闭和释放游标,以避免资源泄漏和性能问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值