1、@SQL 拼接后的SQL語句,可以是你任意需要的SQL語句如:SET @SQL='SELECT * FROM table WHERE ID=@id' 注意此處的@SQL必須且只能是NTEXT、NVARCHAR、NCHAR類型,如果是其它類型的話其它地方明明沒有問題卻會報 "過程需要類型為 'ntext/nchar/nvarchar' 的參數(shù)"這個錯誤。同時,如果這里需要傳入表名稱的話則應(yīng)這樣寫:SET @SQL='SELECT * FROM '+@table+'WHERE ID=@id' ,因為上面?zhèn)魅氲闹凳俏谋绢愋凸蕰箦e。
2、@parameters 所拼接的SQL語句里面的參數(shù),按上面的話這里應(yīng)該是:SET @parameters='@id INT' 同時這個參數(shù)的類型也必須且只能是NTEXT、NVARCHAR、NCHAR類型 3、調(diào)用:sp_executesql param1(,param2) 其中param1一般我們作為是@SQL,后面的參數(shù)則是我們在@sql中的參數(shù)了,但這里要注意的是傳參的時候必須是對應(yīng)的:
復制代碼 代碼如下:
DECLARE @InputId INT ; SET @InputId=1; param2為:@id=@InputId;
以下是寫的一個簡單的通用分頁,有需要可以自行修改:
復制代碼 代碼如下:
ALTER PROCEDURE sp_pager ( @TableName nvarchar(50), -- 表名 @ReturnFields nvarchar(200) = '*', -- 需要返回的列 @PageSize int = 50, -- 每頁記錄數(shù) @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