萬盛學電腦網

 萬盛學電腦網 >> 數據庫 >> 數據庫綜合 >> 動態SQL語句使用心得

動態SQL語句使用心得

本文是一篇有關動態SQL語句使用的文章,有需要的朋友可以參考下。

動態SQL需要准備以下內容:

1、@SQL 拼接後的SQL語句,可以是你任意需要的SQL語句如:SET @SQL='SELECT * FROM table WHERE ID=@id' 注意此處的@SQL必須且只能是NTEXT、NVARCHAR、NCHAR類型,如果是其它類型的話其它地方明明沒有問題卻會報 "過程需要類型為 'ntext/nchar/nvarchar' 的參數"這個錯誤。同時,如果這裡需要傳入表名稱的話則應這樣寫:SET @SQL='SELECT * FROM '+@table+'WHERE ID=@id' ,因為上面傳入的值是文本類型故會報錯。

2、@parameters 所拼接的SQL語句裡面的參數,按上面的話這裡應該是:SET @parameters='@id INT' 同時這個參數的類型也必須且只能是NTEXT、NVARCHAR、NCHAR類型

3、調用:sp_executesql param1(,param2) 其中param1一般我們作為是@SQL,後面的參數則是我們在@sql中的參數了,但這裡要注意的是傳參的時候必須是對應的:

復制代碼 代碼如下:

DECLARE @InputId INT ;

SET @InputId=1;

param2為:@id=@InputId;

以下是寫的一個簡單的通用分頁,有需要可以自行修改:

復制代碼 代碼如下:

ALTER PROCEDURE sp_pager

(

@TableName nvarchar(50), -- 表名

@ReturnFields nvarchar(200) = '*', -- 需要返回的列

@PageSize int = 50, -- 每頁記錄數

@PageIndex int = 1 -- 當前頁碼

)

AS

DECLARE @SQL NVARCHAR(1000)

DECLARE @paramters NVARCHAR(200)

BEGIN

SET NOCOUNT ON

SET @SQL='SELECT '+@ReturnFields+' FROM '+@TableName+' WHERE ID>(SELECT TOP 1 ID FROM (SELECT TOP '+CAST(@PageSize*@PageIndex AS VARCHAR)+' ID FROM '+@TableName+ ' ORDER BY ID )AS A ORDER BY ID DESC)'

PRINT @SQL

EXECUTE sp_executesql @SQL,@paramters,@columns=@ReturnFields

END

1、@SQL 拼接後的SQL語句,可以是你任意需要的SQL語句如:SET @SQL='SELECT * FROM table WHERE ID=@id' 注意此處的@SQL必須且只能是NTEXT、NVARCHAR、NCHAR類型,如果是其它類型的話其它地方明明沒有問題卻會報 "過程需要類型為 'ntext/nchar/nvarchar' 的參數"這個錯誤。同時,如果這裡需要傳入表名稱的話則應這樣寫:SET @SQL='SELECT * FROM '+@table+'WHERE ID=@id' ,因為上面傳入的值是文本類型故會報錯。

2、@parameters 所拼接的SQL語句裡面的參數,按上面的話這裡應該是:SET @parameters='@id INT' 同時這個參數的類型也必須且只能是NTEXT、NVARCHAR、NCHAR類型

3、調用:sp_executesql param1(,param2) 其中param1一般我們作為是@SQL,後面的參數則是我們在@sql中的參數了,但這裡要注意的是傳參的時候必須是對應的:

復制代碼 代碼如下:

DECLARE @InputId INT ;

SET @InputId=1;

param2為:@id=@InputId;

以下是寫的一個簡單的通用分頁,有需要可以自行修改:

復制代碼 代碼如下:

ALTER PROCEDURE sp_pager

(

@TableName nvarchar(50), -- 表名

@ReturnFields nvarchar(200) = '*', -- 需要返回的列

@PageSize int = 50, -- 每頁記錄數

@PageIndex int = 1 -- 當前頁碼

)

AS

DECLARE @SQL NVARCHAR(1000)

DECLARE @paramters NVARCHAR(200)

BEGIN

SET NOCOUNT ON

SET @SQL='SELECT '+@ReturnFields+' FROM '+@TableName+' WHERE ID>(SELECT TOP 1 ID FROM (SELECT TOP '+CAST(@PageSize*@PageIndex AS VARCHAR)+' ID FROM '+@TableName+ ' ORDER BY ID )AS A ORDER BY ID DESC)'

PRINT @SQL

EXECUTE sp_executesql @SQL,@paramters,@columns=@ReturnFields

END。

上就是精品為大家提供關於動態SQL語句使用的文章,希望對大家有所幫助。

copyright © 萬盛學電腦網 all rights reserved