動(dòng)態(tài)SQL語(yǔ)句使用心得
更新時(shí)間:2010年05月11日 19:43:56 作者:
最近在學(xué)習(xí)期間接觸了動(dòng)態(tài)SQL操作,然后小總結(jié)了一下給出自己的心得。
在我們的項(xiàng)目中經(jīng)常需要用到分面功能,而我以前呢用的方法現(xiàn)在看起來(lái)都是那麼的笨拙,當(dāng)時(shí)是這樣做的,每當(dāng)要進(jìn)行數(shù)據(jù)分頁(yè)時(shí)就專們針對(duì)那個(gè)表做分頁(yè),大家別笑,以前確實(shí)好笨。呵呵,雖然當(dāng)時(shí)也有一個(gè)想法就是希望能夠傳入一張表進(jìn)去進(jìn)行操作,但那樣的話編譯是通不過(guò)的,因?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語(yǔ)句,可以是你任意需要的SQL語(yǔ)句如:SET @SQL='SELECT * FROM table WHERE ID=@id' 注意此處的@SQL必須且只能是NTEXT、NVARCHAR、NCHAR類型,如果是其它類型的話其它地方明明沒有問(wèn)題卻會(huì)報(bào) "過(guò)程需要類型為 'ntext/nchar/nvarchar' 的參數(shù)"這個(gè)錯(cuò)誤。同時(shí),如果這里需要傳入表名稱的話則應(yīng)這樣寫:SET @SQL='SELECT * FROM '+@table+'WHERE ID=@id' ,因?yàn)樯厦鎮(zhèn)魅氲闹凳俏谋绢愋凸蕰?huì)報(bào)錯(cuò)。
2、@parameters 所拼接的SQL語(yǔ)句里面的參數(shù),按上面的話這里應(yīng)該是:SET @parameters='@id INT' 同時(shí)這個(gè)參數(shù)的類型也必須且只能是NTEXT、NVARCHAR、NCHAR類型
3、調(diào)用:sp_executesql param1(,param2) 其中param1一般我們作為是@SQL,后面的參數(shù)則是我們?cè)贎sql中的參數(shù)了,但這里要注意的是傳參的時(shí)候必須是對(duì)應(yīng)的:
DECLARE @InputId INT ;
SET @InputId=1;
param2為:@id=@InputId;
以下是寫的一個(gè)簡(jiǎn)單的通用分頁(yè),有需要可以自行修改:
ALTER PROCEDURE sp_pager
(
@TableName nvarchar(50), -- 表名
@ReturnFields nvarchar(200) = '*', -- 需要返回的列
@PageSize int = 50, -- 每頁(yè)記錄數(shù)
@PageIndex int = 1 -- 當(dāng)前頁(yè)碼
)
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
動(dòng)態(tài)SQL需要準(zhǔn)備以下內(nèi)容:
1、@SQL 拼接后的SQL語(yǔ)句,可以是你任意需要的SQL語(yǔ)句如:SET @SQL='SELECT * FROM table WHERE ID=@id' 注意此處的@SQL必須且只能是NTEXT、NVARCHAR、NCHAR類型,如果是其它類型的話其它地方明明沒有問(wèn)題卻會(huì)報(bào) "過(guò)程需要類型為 'ntext/nchar/nvarchar' 的參數(shù)"這個(gè)錯(cuò)誤。同時(shí),如果這里需要傳入表名稱的話則應(yīng)這樣寫:SET @SQL='SELECT * FROM '+@table+'WHERE ID=@id' ,因?yàn)樯厦鎮(zhèn)魅氲闹凳俏谋绢愋凸蕰?huì)報(bào)錯(cuò)。
2、@parameters 所拼接的SQL語(yǔ)句里面的參數(shù),按上面的話這里應(yīng)該是:SET @parameters='@id INT' 同時(shí)這個(gè)參數(shù)的類型也必須且只能是NTEXT、NVARCHAR、NCHAR類型
3、調(diào)用:sp_executesql param1(,param2) 其中param1一般我們作為是@SQL,后面的參數(shù)則是我們?cè)贎sql中的參數(shù)了,但這里要注意的是傳參的時(shí)候必須是對(duì)應(yīng)的:
復(fù)制代碼 代碼如下:
DECLARE @InputId INT ;
SET @InputId=1;
param2為:@id=@InputId;
以下是寫的一個(gè)簡(jiǎn)單的通用分頁(yè),有需要可以自行修改:
復(fù)制代碼 代碼如下:
ALTER PROCEDURE sp_pager
(
@TableName nvarchar(50), -- 表名
@ReturnFields nvarchar(200) = '*', -- 需要返回的列
@PageSize int = 50, -- 每頁(yè)記錄數(shù)
@PageIndex int = 1 -- 當(dāng)前頁(yè)碼
)
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
相關(guān)文章
SQL學(xué)習(xí)筆記八 索引,表連接,子查詢,ROW_NUMBER
SQL學(xué)習(xí)筆記八 索引,表連接,子查詢,ROW_NUMBER,學(xué)習(xí)sqlserver的朋友可以看下。2011-08-08sqlserver數(shù)據(jù)庫(kù)導(dǎo)入方法的詳細(xì)圖文教程
導(dǎo)入數(shù)據(jù)也是數(shù)據(jù)庫(kù)操作中使用頻繁的功能,下面這篇文章主要給大家介紹了關(guān)于sqlserver數(shù)據(jù)庫(kù)導(dǎo)入方法的詳細(xì)圖文教程,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-10-10sql server創(chuàng)建臨時(shí)表的兩種寫法和刪除臨時(shí)表
這篇文章主要介紹了sql server創(chuàng)建臨時(shí)表的兩種寫法和刪除臨時(shí)表 ,需要的朋友可以參考下2015-07-07SQL Server誤區(qū)30日談 第15天 CheckPoint只會(huì)將已提交的事務(wù)寫入磁盤
這個(gè)誤區(qū)是由于太多人對(duì)日志和恢復(fù)系統(tǒng)缺少全面的了解而存在已久。CheckPoint會(huì)將自上次CheckPoint以來(lái)所有在內(nèi)存中改變的頁(yè)寫回磁盤(譯者注:也就是臟頁(yè)),或是在上一個(gè)CheckPoint讀入內(nèi)存的臟頁(yè)寫入磁盤2013-01-01Sql Server事務(wù)語(yǔ)法及使用方法實(shí)例分析
這篇文章主要介紹了Sql Server事務(wù)語(yǔ)法及使用方法,結(jié)合實(shí)例形式分析了Sql Server事務(wù)的概念、原理及相關(guān)使用技巧,需要的朋友可以參考下2019-02-02sqlserver建立新用戶及關(guān)聯(lián)數(shù)據(jù)庫(kù)教程
本文講的是SQLserver數(shù)據(jù)庫(kù)創(chuàng)建新用戶方法以及賦予此用戶特定權(quán)限的方法,非常的簡(jiǎn)單實(shí)用,有需要的小伙伴可以參考下2018-01-01