MSSQL 臨時表學習

 在家學習下MSSQL的零食表玩法 經過一個存儲過程 由於不知道怎麼怎麼在存儲過程裏動態調用SQL 因此不得不想另想辦法 因此想到了臨時表的辦法 其關鍵點就是在獲得的條數數據儲存到臨時表中而後再讀取臨時表 從而達到獲取所有條數的目的 其中也學到了很多新東西sql

1.臨時表的判斷存在的寫法  (臨時表表名 #tt)函數

if(exists(select * from tempdb..sysobjects where id = OBJECT_ID('tempdb..#tt') ) ) 學習

2.臨時表的概念table

能夠建立本地和全局臨時表。本地臨時表僅在當前會話中可見;全局臨時表在全部會話中均可見。
本地臨時表的名稱前面有一個編號符 (#table_name),而全局臨時表的名稱前面有兩個編號符 (##table_name)。變量

通常都是用本地臨時的(#) 其餘人看不到 建立方法和建立表同樣只是表名前面有個#object

3.存儲過程當中動態執行SQL的函數 sp_executesql 記得動態SQL的變量類型不能爲varchar 必須是N開頭的 例如nvarcharselect

exec sp_executesql  @sqllen, N'@TotleCount int output',@TotleCount output 方法

 

 

原版用臨時表實現的結果im

if(exists(select * from sysobjects where id= OBJECT_ID('procTest') ))
begin
drop proc procTest
end 數據

go
create proc procTest
@FeeID varchar(100),
@Money varchar(100),
@Index int,
@Size int,
@TotleCount int output
as
if(exists(select * from tempdb..sysobjects where id = OBJECT_ID('tempdb..#tt') ) )
begin
truncate table #tt
end
else
begin
create table #tt
(
tLen int
)
end
declare @sql varchar(max)
declare @sqllen varchar(max)
set @sql='select ROW_NUMBER() over(order by main_time) as rowIndex ,* from main where 1=1 '
if(ISNULL( @FeeID,'')!='')
begin
set @sql+= ' and main_feeId='+@FeeID
end
if(ISNULL( @Money,'')!='')
begin
set @sql+= ' and main_money='+@Money
end
declare @start int
declare @end int
set @start= (@Index-1)*@Size+1
set @end=@Size*@Index
set @sqllen=' insert into #tt select count(1) from ('+@sql+') t '
--print(@sqllen)
exec(@sqllen)
select @TotleCount=tLen from #tt
set @sql= 'select * from ( '+@sql+') t where rowIndex between '+ CONVERT(varchar(10), @start) +' and '+ CONVERT(varchar(10), @end)
exec(@sql)

改寫後的結果

if(exists(select * from sysobjects where id= OBJECT_ID('procTest') ))
begin
drop proc procTest
end

go
create proc procTest
@FeeID varchar(100),
@Money varchar(100),
@Index int,
@Size int,
@TotleCount int output
as

declare @sql varchar(max)
declare @sqllen nvarchar(max)
set @sql='select ROW_NUMBER() over(order by main_time) as rowIndex ,* from main where 1=1 '
if(ISNULL( @FeeID,'')!='')
begin
set @sql+= ' and main_feeId='+@FeeID
end
if(ISNULL( @Money,'')!='')
begin
set @sql+= ' and main_money='+@Money
end
declare @start int
declare @end int
set @start= (@Index-1)*@Size+1
set @end=@Size*@Index

set @sqllen=' select @TotleCount= count(1) from ('+@sql+') t '
exec sp_executesql @sqllen, N'@TotleCount int output',@TotleCount output

set @sql= 'select * from ( '+@sql+') t where rowIndex between '+ CONVERT(varchar(10), @start) +' and '+ CONVERT(varchar(10), @end)
exec(@sql)

 

調用

declare @aa int exec procTest '7','',1,40, @aa output select @aa

相關文章
相關標籤/搜索