欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

動態(tài)SQL語句使用心得

 更新時間:2010年05月11日 19:43:56   作者:  
最近在學習期間接觸了動態(tài)SQL操作,然后小總結了一下給出自己的心得。
在我們的項目中經常需要用到分面功能,而我以前呢用的方法現(xiàn)在看起來都是那麼的笨拙,當時是這樣做的,每當要進行數(shù)據(jù)分頁時就專們針對那個表做分頁,大家別笑,以前確實好笨。呵呵,雖然當時也有一個想法就是希望能夠傳入一張表進去進行操作,但那樣的話編譯是通不過的,因為FROM后面操作的是表變量,而不能是我們自定義的變量,所以當時沒有深追究,現(xiàn)在為當時不深入學習而BS一下。

動態(tài)SQL需要準備以下內容:

1、@SQL 拼接后的SQL語句,可以是你任意需要的SQL語句如:SET @SQL='SELECT * FROM table WHERE ID=@id' 注意此處的@SQL必須且只能是NTEXT、NVARCHAR、NCHAR類型,如果是其它類型的話其它地方明明沒有問題卻會報 "過程需要類型為 'ntext/nchar/nvarchar' 的參數(shù)"這個錯誤。同時,如果這里需要傳入表名稱的話則應這樣寫:SET @SQL='SELECT * FROM '+@table+'WHERE ID=@id' ,因為上面?zhèn)魅氲闹凳俏谋绢愋凸蕰箦e。

2、@parameters 所拼接的SQL語句里面的參數(shù),按上面的話這里應該是:SET @parameters='@id INT' 同時這個參數(shù)的類型也必須且只能是NTEXT、NVARCHAR、NCHAR類型
3、調用:sp_executesql param1(,param2) 其中param1一般我們作為是@SQL,后面的參數(shù)則是我們在@sql中的參數(shù)了,但這里要注意的是傳參的時候必須是對應的:

復制代碼 代碼如下:

  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

相關文章

最新評論