SQL中print、sp_helptext的限制與擴(kuò)展
在SQL中,使用動態(tài)SQL是很常見的。有些復(fù)雜的計算,或是存儲過程,代碼很長,中間可能有多次執(zhí)行SQL語句。而調(diào)試拼串的SQL語句卻是件痛苦的事,很難看出來運行的語句是什么。所以我會經(jīng)常使用print這個命令把運行前的語句打印到屏幕上,然后復(fù)制出來到另一個窗口進(jìn)行調(diào)試、修改,這樣就比較方便了。但是這個print命令有一些限制,在單字節(jié)符集下,最大只能打印打印8000個字符的長度,而在雙字節(jié)字符集是4000個。
以下存儲過程可以打印完整的信息,不受長度的限制。代碼如下:
IF OBJECT_ID(N'sp_print_all') IS NOT NULL BEGIN DROP PROCEDURE sp_print_all END GO CREATE PROCEDURE sp_print_all (@dynamic_sql NVARCHAR(MAX)) AS DECLARE @start INT DECLARE @len INT SET @start = 1 SET @len = 4000 WHILE (@start < LEN(@dynamic_sql)) BEGIN PRINT SUBSTRING(@dynamic_sql, @start, @len) SET @start = @start + @len END PRINT SUBSTRING(@dynamic_sql, @start, @len) GO
code-1
還有一個存儲sp_helptext,可以查詢存儲過程,函數(shù)等代碼,使用起來也比較方便,但也有長度的限制,而且打印出來的格式跟源代碼的格式有些對應(yīng)不上。寫了一個自定義存儲過程來代替,代碼如下:
IF OBJECT_ID(N'sp_helptext_user') IS NOT NULL BEGIN DROP PROCEDURE sp_helptext_user END GO CREATE PROCEDURE sp_helptext_user(@obj_name NVARCHAR(200) = '') AS SET NOCOUNT ON; DECLARE @text NVARCHAR(MAX) ,@i INT ,@text2 NVARCHAR(MAX) ,@db_name SYSNAME ,@obj_id BIGINT SET @db_name = PARSENAME(@obj_name ,3) IF @db_name IS NULL SET @db_name = DB_NAME() ELSE IF @db_name <> DB_NAME() BEGIN RAISERROR(15250 ,-1 ,-1) RETURN (1) END SET @obj_id = OBJECT_ID(@obj_name) IF @obj_id IS NULL BEGIN RAISERROR(15009 ,-1 ,-1 ,@obj_name ,@db_name) RETURN (1) END SELECT @text = [definition] FROM sys.all_sql_modules WHERE [object_id] = @obj_id WHILE LEN(@text) > 2000 BEGIN SET @i = CHARINDEX(CHAR(13) ,@text ,2000) SET @text2 = LEFT(@text ,@i) SET @text = SUBSTRING(@text ,@i + 2 ,LEN(@text)) PRINT @text2 END PRINT @text SET NOCOUNT OFF; GO
code-2
當(dāng)然,查看源代碼有多種方法,可以在SSMS上操作等,看個人習(xí)慣或方便操作了。
詳解sp_helptext
顯示規(guī)則、默認(rèn)值、未加密的存儲過程、用戶定義函數(shù)、觸發(fā)器或視圖的文本。
語法
sp_helptext [ @objname = ] 'name'
參數(shù)
[@objname =] 'name'
對象的名稱,將顯示該對象的定義信息。對象必須在當(dāng)前數(shù)據(jù)庫中。name 的數(shù)據(jù)類型為 nvarchar(776),沒有默認(rèn)值。
返回代碼值
0(成功)或 1(失敗)
注釋
sp_helptext 在多個行中顯示用來創(chuàng)建對象的文本,其中每行有 Transact-SQL 定義的 255 個字符。這些定義只駐留在當(dāng)前數(shù)據(jù)庫的 syscomments 表的文本中。
權(quán)限
執(zhí)行權(quán)限默認(rèn)授予 public 角色。
示例
下面的示例顯示 employee_insupd 觸發(fā)器的文本,該觸發(fā)器在數(shù)據(jù)庫 pubs 中。
USE pubs EXEC sp_helptext 'employee_insupd'
相關(guān)文章
淺談SQLServer的ISNULL函數(shù)與Mysql的IFNULL函數(shù)用法詳解
本篇文章是對SQLServer的ISNULL函數(shù)與Mysql的IFNULL函數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06深入SQLServer中ISNULL與NULLIF的使用詳解
本篇文章是對SQLServer中ISNULL與NULLIF的使用進(jìn)行了詳細(xì)分析介紹,需要的朋友參考下2013-06-06SQL Server中將查詢結(jié)果轉(zhuǎn)換為Json格式腳本分享
這篇文章主要介紹了SQL Server中將查詢結(jié)果轉(zhuǎn)換為Json格式腳本分享,本文直接給出實現(xiàn)代碼,需要的朋友可以參考下2015-02-02SQL Server查找表名或列名中包含空格的表和列實例代碼
這篇文章主要給大家介紹了關(guān)于SQL Server如何查找表名或列名中包含空格的表和列的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧2018-09-09SQL Server誤區(qū)30日談 第15天 CheckPoint只會將已提交的事務(wù)寫入磁盤
這個誤區(qū)是由于太多人對日志和恢復(fù)系統(tǒng)缺少全面的了解而存在已久。CheckPoint會將自上次CheckPoint以來所有在內(nèi)存中改變的頁寫回磁盤(譯者注:也就是臟頁),或是在上一個CheckPoint讀入內(nèi)存的臟頁寫入磁盤2013-01-01sqlserver 此數(shù)據(jù)庫沒有有效所有者錯誤的解決方法
此數(shù)據(jù)庫沒有有效所有者,因此無法安裝數(shù)據(jù)庫關(guān)系圖支持對象。若要繼續(xù),請首先使用“數(shù)據(jù)庫屬性”對話框的“文件”頁或Alter AUTHORIZATION語句將數(shù)據(jù)庫所有者設(shè)置為有效登錄名,然后再添加數(shù)據(jù)庫關(guān)系圖支持對象。2010-04-04MSSQL轉(zhuǎn)MYSQL,gb2312轉(zhuǎn)utf-8無亂碼解決方法
MSSQL轉(zhuǎn)MYSQL,gb2312轉(zhuǎn)utf-8無亂碼解決方法,需要的朋友可以參考下。2010-06-06