国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

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

2024-08-31 00:58:45
字體:
供稿:網(wǎng)友
在我們的項(xiàng)目中經(jīng)常需要用到分面功能,而我以前呢用的方法現(xiàn)在看起來都是那麼的笨拙,當(dāng)時(shí)是這樣做的,每當(dāng)要進(jìn)行數(shù)據(jù)分頁時(shí)就專們針對那個(gè)表做分頁,大家別笑,以前確實(shí)好笨。呵呵,雖然當(dāng)時(shí)也有一個(gè)想法就是希望能夠傳入一張表進(jìn)去進(jìn)行操作,但那樣的話編譯是通不過的,因?yàn)镕ROM后面操作的是表變量,而不能是我們自定義的變量,所以當(dāng)時(shí)沒有深追究,現(xiàn)在為當(dāng)時(shí)不深入學(xué)習(xí)而BS一下。

動(dòng)態(tài)SQL需要準(zhǔn)備以下內(nèi)容:

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

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

復(fù)制代碼 代碼如下:


  DECLARE @InputId INT ;
  SET @InputId=1;
   param2為:@id=@InputId;



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

復(fù)制代碼 代碼如下:


ALTER PROCEDURE sp_pager
(
@TableName nvarchar(50), -- 表名
@ReturnFields nvarchar(200) = '*', -- 需要返回的列
@PageSize int = 50, -- 每頁記錄數(shù)
@PageIndex int = 1 -- 當(dāng)前頁碼
)
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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 晋江市| 察隅县| 塔城市| 祁连县| 菏泽市| 台中县| 遂昌县| 万源市| 江城| 准格尔旗| 梁河县| 浦城县| 彰化县| 吉木乃县| 东乡族自治县| 贵定县| 洪湖市| 普洱| 台前县| 正蓝旗| 洛隆县| 莱西市| 赤水市| 洛浦县| 曲沃县| 中牟县| 成安县| 万年县| 光泽县| 山阴县| 平遥县| 婺源县| 吉木乃县| 丰都县| 娄烦县| 吉林省| 天柱县| 措勤县| 洛南县| 双柏县| 晴隆县|