濮阳杆衣贸易有限公司

主頁 > 知識庫 > 動(dòng)態(tài)SQL語句使用心得

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

熱門標(biāo)簽:鎮(zhèn)江網(wǎng)路外呼系統(tǒng)供應(yīng)商 外呼運(yùn)營商線路收費(fèi) 貴州房產(chǎn)智能外呼系統(tǒng)供應(yīng)商 申請400電話在哪辦理流程 小e電話機(jī)器人 一個(gè)導(dǎo)航軟件能用幾個(gè)地圖標(biāo)注點(diǎn) 百度地圖標(biāo)注改顏色 臨沂智能電銷機(jī)器人加盟哪家好 電銷外呼有錄音系統(tǒ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類型,如果是其它類型的話其它地方明明沒有問題卻會(huì)報(bào) "過程需要類型為 '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語句里面的參數(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
您可能感興趣的文章:
  • 基于Oracle的高性能動(dòng)態(tài)SQL程序開發(fā)
  • 為什么ASP中執(zhí)行動(dòng)態(tài)SQL總報(bào)錯(cuò)誤信息?提示語句語法錯(cuò)誤
  • 批處理 動(dòng)態(tài)sql
  • sqlserver 支持定位當(dāng)前頁,自定義排序的分頁SQL(拒絕動(dòng)態(tài)SQL)
  • 編程經(jīng)驗(yàn)點(diǎn)滴 動(dòng)態(tài)SQL的拼接技巧
  • oracle中動(dòng)態(tài)SQL使用詳細(xì)介紹
  • mysql存儲過程 在動(dòng)態(tài)SQL內(nèi)獲取返回值的方法詳解
  • MySQL 存儲過程中執(zhí)行動(dòng)態(tài)SQL語句的方法
  • mybatis的動(dòng)態(tài)sql詳解(精)

標(biāo)簽:合肥 保定 澳門 晉城 日照 延邊 嘉興 三明

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《動(dòng)態(tài)SQL語句使用心得》,本文關(guān)鍵詞  動(dòng)態(tài),SQL,語句,使用,心得,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《動(dòng)態(tài)SQL語句使用心得》相關(guān)的同類信息!
  • 本頁收集關(guān)于動(dòng)態(tài)SQL語句使用心得的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    西贡区| 大理市| 青铜峡市| 咸宁市| 濮阳县| 宜兴市| 麻阳| 荆门市| 延庆县| 山阴县| 陕西省| 宁国市| 稻城县| 鸡泽县| 乌什县| 河南省| 光山县| 新源县| 阳曲县| 定远县| 西安市| 南康市| 孟州市| 新干县| 阳新县| 宁远县| 延寿县| 东宁县| 山东| 汉阴县| 涟源市| 庄河市| 德江县| 定结县| 湘乡市| 新余市| 彭阳县| 绥宁县| 北辰区| 普兰店市| 勃利县|